Commit d43ab298 authored by Johannes Berg's avatar Johannes Berg Committed by Luca Coelho

iwlwifi: copy iwl_he_capa for modifications

This data is not necessarily the same across devices as we may
modify it due to the number of antennas and for overrides (though
in practice overrides are likely to be identical), so modifying
the global data is wrong.

Make a copy of it in the NVM data and modify it there instead.
Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
Signed-off-by: default avatarLuca Coelho <luciano.coelho@intel.com>
Link: https://lore.kernel.org/r/iwlwifi.20201209231352.6b4ee30c59e4.I0c30ef78b3bf727fe80b16a19c7588016d6b04bf@changeidSigned-off-by: default avatarLuca Coelho <luciano.coelho@intel.com>
parent 4adfaf9b
...@@ -99,6 +99,12 @@ struct iwl_nvm_data { ...@@ -99,6 +99,12 @@ struct iwl_nvm_data {
bool lar_enabled; bool lar_enabled;
bool vht160_supported; bool vht160_supported;
struct ieee80211_supported_band bands[NUM_NL80211_BANDS]; struct ieee80211_supported_band bands[NUM_NL80211_BANDS];
struct {
struct ieee80211_sband_iftype_data low[2];
struct ieee80211_sband_iftype_data high[2];
} iftd;
struct ieee80211_channel channels[]; struct ieee80211_channel channels[];
}; };
......
...@@ -580,7 +580,7 @@ static void iwl_init_vht_hw_capab(struct iwl_trans *trans, ...@@ -580,7 +580,7 @@ static void iwl_init_vht_hw_capab(struct iwl_trans *trans,
cpu_to_le16(IEEE80211_VHT_EXT_NSS_BW_CAPABLE); cpu_to_le16(IEEE80211_VHT_EXT_NSS_BW_CAPABLE);
} }
static struct ieee80211_sband_iftype_data iwl_he_capa[] = { static const struct ieee80211_sband_iftype_data iwl_he_capa[] = {
{ {
.types_mask = BIT(NL80211_IFTYPE_STATION), .types_mask = BIT(NL80211_IFTYPE_STATION),
.he_cap = { .he_cap = {
...@@ -748,7 +748,30 @@ static void iwl_init_he_hw_capab(struct iwl_trans *trans, ...@@ -748,7 +748,30 @@ static void iwl_init_he_hw_capab(struct iwl_trans *trans,
struct ieee80211_supported_band *sband, struct ieee80211_supported_band *sband,
u8 tx_chains, u8 rx_chains) u8 tx_chains, u8 rx_chains)
{ {
sband->iftype_data = iwl_he_capa; struct ieee80211_sband_iftype_data *iftype_data;
/* should only initialize once */
if (WARN_ON(sband->iftype_data))
return;
BUILD_BUG_ON(sizeof(data->iftd.low) != sizeof(iwl_he_capa));
BUILD_BUG_ON(sizeof(data->iftd.high) != sizeof(iwl_he_capa));
switch (sband->band) {
case NL80211_BAND_2GHZ:
iftype_data = data->iftd.low;
break;
case NL80211_BAND_5GHZ:
iftype_data = data->iftd.high;
break;
default:
WARN_ON(1);
return;
}
memcpy(iftype_data, iwl_he_capa, sizeof(iwl_he_capa));
sband->iftype_data = iftype_data;
sband->n_iftype_data = ARRAY_SIZE(iwl_he_capa); sband->n_iftype_data = ARRAY_SIZE(iwl_he_capa);
/* If not 2x2, we need to indicate 1x1 in the Midamble RX Max NSTS */ /* If not 2x2, we need to indicate 1x1 in the Midamble RX Max NSTS */
...@@ -756,11 +779,11 @@ static void iwl_init_he_hw_capab(struct iwl_trans *trans, ...@@ -756,11 +779,11 @@ static void iwl_init_he_hw_capab(struct iwl_trans *trans,
int i; int i;
for (i = 0; i < sband->n_iftype_data; i++) { for (i = 0; i < sband->n_iftype_data; i++) {
iwl_he_capa[i].he_cap.he_cap_elem.phy_cap_info[1] &= iftype_data[i].he_cap.he_cap_elem.phy_cap_info[1] &=
~IEEE80211_HE_PHY_CAP1_MIDAMBLE_RX_TX_MAX_NSTS; ~IEEE80211_HE_PHY_CAP1_MIDAMBLE_RX_TX_MAX_NSTS;
iwl_he_capa[i].he_cap.he_cap_elem.phy_cap_info[2] &= iftype_data[i].he_cap.he_cap_elem.phy_cap_info[2] &=
~IEEE80211_HE_PHY_CAP2_MIDAMBLE_RX_TX_MAX_NSTS; ~IEEE80211_HE_PHY_CAP2_MIDAMBLE_RX_TX_MAX_NSTS;
iwl_he_capa[i].he_cap.he_cap_elem.phy_cap_info[7] &= iftype_data[i].he_cap.he_cap_elem.phy_cap_info[7] &=
~IEEE80211_HE_PHY_CAP7_MAX_NC_MASK; ~IEEE80211_HE_PHY_CAP7_MAX_NC_MASK;
} }
} }
......
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