Commit 5f809baf authored by Johannes Berg's avatar Johannes Berg

wifi: iwlwifi: mvm: iterate active links for STA queues

During HW restart in eSR, links allocated in a station and links
active in the interface may differ. Use for_each_sta_active_link
to capture this.
Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
Signed-off-by: default avatarGregory Greenman <gregory.greenman@intel.com>
Link: https://lore.kernel.org/r/20230921110726.7ee1f1a55e1c.I410c512d1fad7d1cf9b2d2a3451a312821dc816d@changeidSigned-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
parent 4ea1ed1d
...@@ -865,11 +865,11 @@ int iwl_mvm_tvqm_enable_txq(struct iwl_mvm *mvm, ...@@ -865,11 +865,11 @@ int iwl_mvm_tvqm_enable_txq(struct iwl_mvm *mvm,
if (sta) { if (sta) {
struct iwl_mvm_sta *mvmsta = iwl_mvm_sta_from_mac80211(sta); struct iwl_mvm_sta *mvmsta = iwl_mvm_sta_from_mac80211(sta);
struct ieee80211_link_sta *link_sta;
unsigned int link_id; unsigned int link_id;
for (link_id = 0; rcu_read_lock();
link_id < ARRAY_SIZE(mvmsta->link); for_each_sta_active_link(mvmsta->vif, sta, link_sta, link_id) {
link_id++) {
struct iwl_mvm_link_sta *link = struct iwl_mvm_link_sta *link =
rcu_dereference_protected(mvmsta->link[link_id], rcu_dereference_protected(mvmsta->link[link_id],
lockdep_is_held(&mvm->mutex)); lockdep_is_held(&mvm->mutex));
...@@ -879,6 +879,7 @@ int iwl_mvm_tvqm_enable_txq(struct iwl_mvm *mvm, ...@@ -879,6 +879,7 @@ int iwl_mvm_tvqm_enable_txq(struct iwl_mvm *mvm,
sta_mask |= BIT(link->sta_id); sta_mask |= BIT(link->sta_id);
} }
rcu_read_unlock();
} else { } else {
sta_mask |= BIT(sta_id); sta_mask |= BIT(sta_id);
} }
......
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