Commit 2cc25e4b authored by Aloka Dixit's avatar Aloka Dixit Committed by Johannes Berg

wifi: mac80211: configure puncturing bitmap

- Configure the bitmap in link_conf and notify the driver.
- Modify 'change' in ieee80211_start_ap() from u32 to u64 to support
BSS_CHANGED_EHT_PUNCTURING.
- Propagate the bitmap in channel switch events to userspace.
Signed-off-by: default avatarAloka Dixit <quic_alokad@quicinc.com>
Signed-off-by: default avatarMuna Sinada <quic_msinada@quicinc.com>
Link: https://lore.kernel.org/r/20230131001227.25014-5-quic_alokad@quicinc.comSigned-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
parent b345f063
...@@ -645,6 +645,7 @@ struct ieee80211_fils_discovery { ...@@ -645,6 +645,7 @@ struct ieee80211_fils_discovery {
* @csa_active: marks whether a channel switch is going on. Internally it is * @csa_active: marks whether a channel switch is going on. Internally it is
* write-protected by sdata_lock and local->mtx so holding either is fine * write-protected by sdata_lock and local->mtx so holding either is fine
* for read access. * for read access.
* @csa_punct_bitmap: new puncturing bitmap for channel switch
* @mu_mimo_owner: indicates interface owns MU-MIMO capability * @mu_mimo_owner: indicates interface owns MU-MIMO capability
* @chanctx_conf: The channel context this interface is assigned to, or %NULL * @chanctx_conf: The channel context this interface is assigned to, or %NULL
* when it is not assigned. This pointer is RCU-protected due to the TX * when it is not assigned. This pointer is RCU-protected due to the TX
...@@ -741,6 +742,8 @@ struct ieee80211_bss_conf { ...@@ -741,6 +742,8 @@ struct ieee80211_bss_conf {
u16 eht_puncturing; u16 eht_puncturing;
bool csa_active; bool csa_active;
u16 csa_punct_bitmap;
bool mu_mimo_owner; bool mu_mimo_owner;
struct ieee80211_chanctx_conf __rcu *chanctx_conf; struct ieee80211_chanctx_conf __rcu *chanctx_conf;
......
...@@ -1220,7 +1220,7 @@ static int ieee80211_start_ap(struct wiphy *wiphy, struct net_device *dev, ...@@ -1220,7 +1220,7 @@ static int ieee80211_start_ap(struct wiphy *wiphy, struct net_device *dev,
struct ieee80211_local *local = sdata->local; struct ieee80211_local *local = sdata->local;
struct beacon_data *old; struct beacon_data *old;
struct ieee80211_sub_if_data *vlan; struct ieee80211_sub_if_data *vlan;
u32 changed = BSS_CHANGED_BEACON_INT | u64 changed = BSS_CHANGED_BEACON_INT |
BSS_CHANGED_BEACON_ENABLED | BSS_CHANGED_BEACON_ENABLED |
BSS_CHANGED_BEACON | BSS_CHANGED_BEACON |
BSS_CHANGED_P2P_PS | BSS_CHANGED_P2P_PS |
...@@ -1296,6 +1296,11 @@ static int ieee80211_start_ap(struct wiphy *wiphy, struct net_device *dev, ...@@ -1296,6 +1296,11 @@ static int ieee80211_start_ap(struct wiphy *wiphy, struct net_device *dev,
IEEE80211_HE_PHY_CAP2_UL_MU_FULL_MU_MIMO; IEEE80211_HE_PHY_CAP2_UL_MU_FULL_MU_MIMO;
} }
if (params->eht_cap) {
link_conf->eht_puncturing = params->punct_bitmap;
changed |= BSS_CHANGED_EHT_PUNCTURING;
}
if (sdata->vif.type == NL80211_IFTYPE_AP && if (sdata->vif.type == NL80211_IFTYPE_AP &&
params->mbssid_config.tx_wdev) { params->mbssid_config.tx_wdev) {
err = ieee80211_set_ap_mbssid_options(sdata, err = ieee80211_set_ap_mbssid_options(sdata,
...@@ -3546,6 +3551,12 @@ static int __ieee80211_csa_finalize(struct ieee80211_sub_if_data *sdata) ...@@ -3546,6 +3551,12 @@ static int __ieee80211_csa_finalize(struct ieee80211_sub_if_data *sdata)
lockdep_assert_held(&local->mtx); lockdep_assert_held(&local->mtx);
lockdep_assert_held(&local->chanctx_mtx); lockdep_assert_held(&local->chanctx_mtx);
if (sdata->vif.bss_conf.eht_puncturing != sdata->vif.bss_conf.csa_punct_bitmap) {
sdata->vif.bss_conf.eht_puncturing =
sdata->vif.bss_conf.csa_punct_bitmap;
changed |= BSS_CHANGED_EHT_PUNCTURING;
}
/* /*
* using reservation isn't immediate as it may be deferred until later * using reservation isn't immediate as it may be deferred until later
* with multi-vif. once reservation is complete it will re-schedule the * with multi-vif. once reservation is complete it will re-schedule the
...@@ -3588,7 +3599,7 @@ static int __ieee80211_csa_finalize(struct ieee80211_sub_if_data *sdata) ...@@ -3588,7 +3599,7 @@ static int __ieee80211_csa_finalize(struct ieee80211_sub_if_data *sdata)
return err; return err;
cfg80211_ch_switch_notify(sdata->dev, &sdata->deflink.csa_chandef, 0, cfg80211_ch_switch_notify(sdata->dev, &sdata->deflink.csa_chandef, 0,
0); sdata->vif.bss_conf.eht_puncturing);
return 0; return 0;
} }
...@@ -3850,9 +3861,13 @@ __ieee80211_channel_switch(struct wiphy *wiphy, struct net_device *dev, ...@@ -3850,9 +3861,13 @@ __ieee80211_channel_switch(struct wiphy *wiphy, struct net_device *dev,
goto out; goto out;
} }
if (params->punct_bitmap && !sdata->vif.bss_conf.eht_support)
goto out;
sdata->deflink.csa_chandef = params->chandef; sdata->deflink.csa_chandef = params->chandef;
sdata->deflink.csa_block_tx = params->block_tx; sdata->deflink.csa_block_tx = params->block_tx;
sdata->vif.bss_conf.csa_active = true; sdata->vif.bss_conf.csa_active = true;
sdata->vif.bss_conf.csa_punct_bitmap = params->punct_bitmap;
if (sdata->deflink.csa_block_tx) if (sdata->deflink.csa_block_tx)
ieee80211_stop_vif_queues(local, sdata, ieee80211_stop_vif_queues(local, sdata,
...@@ -3860,7 +3875,8 @@ __ieee80211_channel_switch(struct wiphy *wiphy, struct net_device *dev, ...@@ -3860,7 +3875,8 @@ __ieee80211_channel_switch(struct wiphy *wiphy, struct net_device *dev,
cfg80211_ch_switch_started_notify(sdata->dev, cfg80211_ch_switch_started_notify(sdata->dev,
&sdata->deflink.csa_chandef, 0, &sdata->deflink.csa_chandef, 0,
params->count, params->block_tx, 0); params->count, params->block_tx,
sdata->vif.bss_conf.csa_punct_bitmap);
if (changed) { if (changed) {
ieee80211_link_info_change_notify(sdata, &sdata->deflink, ieee80211_link_info_change_notify(sdata, &sdata->deflink,
......
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