Commit 0ee5bcdd authored by Emmanuel Grumbach's avatar Emmanuel Grumbach

iwlwifi: mvm: BT Coex - set low latency vif as primary

If a vif is in low latency mode, it should be in primary
channel.
Also tell BT Coex about the change when a vif enters or
exits low latency mode.
Reviewed-by: default avatarJohannes Berg <johannes.berg@intel.com>
Signed-off-by: default avatarEmmanuel Grumbach <emmanuel.grumbach@intel.com>
parent 1fb184b4
...@@ -542,6 +542,7 @@ struct iwl_bt_iterator_data { ...@@ -542,6 +542,7 @@ struct iwl_bt_iterator_data {
bool reduced_tx_power; bool reduced_tx_power;
struct ieee80211_chanctx_conf *primary; struct ieee80211_chanctx_conf *primary;
struct ieee80211_chanctx_conf *secondary; struct ieee80211_chanctx_conf *secondary;
bool primary_ll;
}; };
static inline static inline
...@@ -590,7 +591,14 @@ static void iwl_mvm_bt_notif_iterator(void *_data, u8 *mac, ...@@ -590,7 +591,14 @@ static void iwl_mvm_bt_notif_iterator(void *_data, u8 *mac,
return; return;
} }
/* SoftAP / GO will always be primary */ /* low latency is always primary */
if (iwl_mvm_vif_low_latency(mvmvif)) {
data->primary_ll = true;
data->secondary = data->primary;
data->primary = chanctx_conf;
}
if (vif->type == NL80211_IFTYPE_AP) { if (vif->type == NL80211_IFTYPE_AP) {
if (!mvmvif->ap_ibss_active) if (!mvmvif->ap_ibss_active)
return; return;
...@@ -601,9 +609,17 @@ static void iwl_mvm_bt_notif_iterator(void *_data, u8 *mac, ...@@ -601,9 +609,17 @@ static void iwl_mvm_bt_notif_iterator(void *_data, u8 *mac,
if (chanctx_conf == data->primary) if (chanctx_conf == data->primary)
return; return;
/* downgrade the current primary no matter what its type is */ if (!data->primary_ll) {
data->secondary = data->primary; /*
data->primary = chanctx_conf; * downgrade the current primary no matter what its
* type is.
*/
data->secondary = data->primary;
data->primary = chanctx_conf;
} else {
/* there is low latency vif - we will be secondary */
data->secondary = chanctx_conf;
}
return; return;
} }
...@@ -613,7 +629,10 @@ static void iwl_mvm_bt_notif_iterator(void *_data, u8 *mac, ...@@ -613,7 +629,10 @@ static void iwl_mvm_bt_notif_iterator(void *_data, u8 *mac,
if (!vif->bss_conf.assoc) if (!vif->bss_conf.assoc)
return; return;
/* STA / P2P Client, try to be primary if first vif */ /*
* STA / P2P Client, try to be primary if first vif. If we are in low
* latency mode, we are already in primary and just don't do much
*/
if (!data->primary || data->primary == chanctx_conf) if (!data->primary || data->primary == chanctx_conf)
data->primary = chanctx_conf; data->primary = chanctx_conf;
else if (!data->secondary) else if (!data->secondary)
......
...@@ -550,5 +550,8 @@ int iwl_mvm_update_low_latency(struct iwl_mvm *mvm, struct ieee80211_vif *vif, ...@@ -550,5 +550,8 @@ int iwl_mvm_update_low_latency(struct iwl_mvm *mvm, struct ieee80211_vif *vif,
res = iwl_mvm_update_quotas(mvm, NULL); res = iwl_mvm_update_quotas(mvm, NULL);
if (res) if (res)
return res; return res;
iwl_mvm_bt_coex_vif_change(mvm);
return iwl_mvm_power_update_mode(mvm, vif); return iwl_mvm_power_update_mode(mvm, vif);
} }
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