iwlwifi: mvm: rs: avoid ss_force from being reset after tx idle
ss_force is a debugging option to force a certain single stream tx mode. It's not useful if it gets reset after tx idle. Fix that. While at it also make sure any code touching ss_force will only get compiled if debugfs support is configured. Signed-off-by: Eyal Shapira <eyalx.shapira@intel.com> Reviewed-by: Johannes Berg <johannes.berg@intel.com> Signed-off-by: Emmanuel Grumbach <emmanuel.grumbach@intel.com>
This commit is contained in:
parent
e717c16676
commit
878985ce7e
@ -2545,6 +2545,7 @@ static void *rs_alloc_sta(void *mvm_rate, struct ieee80211_sta *sta,
|
|||||||
#ifdef CONFIG_MAC80211_DEBUGFS
|
#ifdef CONFIG_MAC80211_DEBUGFS
|
||||||
lq_sta->pers.dbg_fixed_rate = 0;
|
lq_sta->pers.dbg_fixed_rate = 0;
|
||||||
lq_sta->pers.dbg_fixed_txp_reduction = TPC_INVALID;
|
lq_sta->pers.dbg_fixed_txp_reduction = TPC_INVALID;
|
||||||
|
lq_sta->pers.ss_force = RS_SS_FORCE_NONE;
|
||||||
#endif
|
#endif
|
||||||
lq_sta->pers.chains = 0;
|
lq_sta->pers.chains = 0;
|
||||||
memset(lq_sta->pers.chain_signal, 0, sizeof(lq_sta->pers.chain_signal));
|
memset(lq_sta->pers.chain_signal, 0, sizeof(lq_sta->pers.chain_signal));
|
||||||
@ -3067,19 +3068,21 @@ static void rs_set_lq_ss_params(struct iwl_mvm *mvm,
|
|||||||
if (!iwl_mvm_bt_coex_is_mimo_allowed(mvm, sta))
|
if (!iwl_mvm_bt_coex_is_mimo_allowed(mvm, sta))
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
|
#ifdef CONFIG_MAC80211_DEBUGFS
|
||||||
/* Check if forcing the decision is configured.
|
/* Check if forcing the decision is configured.
|
||||||
* Note that SISO is forced by not allowing STBC or BFER
|
* Note that SISO is forced by not allowing STBC or BFER
|
||||||
*/
|
*/
|
||||||
if (lq_sta->ss_force == RS_SS_FORCE_STBC)
|
if (lq_sta->pers.ss_force == RS_SS_FORCE_STBC)
|
||||||
ss_params |= (LQ_SS_STBC_1SS_ALLOWED | LQ_SS_FORCE);
|
ss_params |= (LQ_SS_STBC_1SS_ALLOWED | LQ_SS_FORCE);
|
||||||
else if (lq_sta->ss_force == RS_SS_FORCE_BFER)
|
else if (lq_sta->pers.ss_force == RS_SS_FORCE_BFER)
|
||||||
ss_params |= (LQ_SS_BFER_ALLOWED | LQ_SS_FORCE);
|
ss_params |= (LQ_SS_BFER_ALLOWED | LQ_SS_FORCE);
|
||||||
|
|
||||||
if (lq_sta->ss_force != RS_SS_FORCE_NONE) {
|
if (lq_sta->pers.ss_force != RS_SS_FORCE_NONE) {
|
||||||
IWL_DEBUG_RATE(mvm, "Forcing single stream Tx decision %d\n",
|
IWL_DEBUG_RATE(mvm, "Forcing single stream Tx decision %d\n",
|
||||||
lq_sta->ss_force);
|
lq_sta->pers.ss_force);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
if (lq_sta->stbc_capable)
|
if (lq_sta->stbc_capable)
|
||||||
ss_params |= LQ_SS_STBC_1SS_ALLOWED;
|
ss_params |= LQ_SS_STBC_1SS_ALLOWED;
|
||||||
@ -3542,7 +3545,7 @@ static ssize_t iwl_dbgfs_ss_force_read(struct file *file,
|
|||||||
};
|
};
|
||||||
|
|
||||||
pos += scnprintf(buf+pos, bufsz-pos, "%s\n",
|
pos += scnprintf(buf+pos, bufsz-pos, "%s\n",
|
||||||
ss_force_name[lq_sta->ss_force]);
|
ss_force_name[lq_sta->pers.ss_force]);
|
||||||
return simple_read_from_buffer(user_buf, count, ppos, buf, pos);
|
return simple_read_from_buffer(user_buf, count, ppos, buf, pos);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3553,12 +3556,12 @@ static ssize_t iwl_dbgfs_ss_force_write(struct iwl_lq_sta *lq_sta, char *buf,
|
|||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
if (!strncmp("none", buf, 4)) {
|
if (!strncmp("none", buf, 4)) {
|
||||||
lq_sta->ss_force = RS_SS_FORCE_NONE;
|
lq_sta->pers.ss_force = RS_SS_FORCE_NONE;
|
||||||
} else if (!strncmp("siso", buf, 4)) {
|
} else if (!strncmp("siso", buf, 4)) {
|
||||||
lq_sta->ss_force = RS_SS_FORCE_SISO;
|
lq_sta->pers.ss_force = RS_SS_FORCE_SISO;
|
||||||
} else if (!strncmp("stbc", buf, 4)) {
|
} else if (!strncmp("stbc", buf, 4)) {
|
||||||
if (lq_sta->stbc_capable) {
|
if (lq_sta->stbc_capable) {
|
||||||
lq_sta->ss_force = RS_SS_FORCE_STBC;
|
lq_sta->pers.ss_force = RS_SS_FORCE_STBC;
|
||||||
} else {
|
} else {
|
||||||
IWL_ERR(mvm,
|
IWL_ERR(mvm,
|
||||||
"can't force STBC. peer doesn't support\n");
|
"can't force STBC. peer doesn't support\n");
|
||||||
@ -3566,7 +3569,7 @@ static ssize_t iwl_dbgfs_ss_force_write(struct iwl_lq_sta *lq_sta, char *buf,
|
|||||||
}
|
}
|
||||||
} else if (!strncmp("bfer", buf, 4)) {
|
} else if (!strncmp("bfer", buf, 4)) {
|
||||||
if (lq_sta->bfer_capable) {
|
if (lq_sta->bfer_capable) {
|
||||||
lq_sta->ss_force = RS_SS_FORCE_BFER;
|
lq_sta->pers.ss_force = RS_SS_FORCE_BFER;
|
||||||
} else {
|
} else {
|
||||||
IWL_ERR(mvm,
|
IWL_ERR(mvm,
|
||||||
"can't force BFER. peer doesn't support\n");
|
"can't force BFER. peer doesn't support\n");
|
||||||
|
@ -332,14 +332,14 @@ struct iwl_lq_sta {
|
|||||||
/* tx power reduce for this sta */
|
/* tx power reduce for this sta */
|
||||||
int tpc_reduce;
|
int tpc_reduce;
|
||||||
|
|
||||||
/* force STBC/BFER/SISO for testing */
|
|
||||||
enum rs_ss_force_opt ss_force;
|
|
||||||
|
|
||||||
/* persistent fields - initialized only once - keep last! */
|
/* persistent fields - initialized only once - keep last! */
|
||||||
struct lq_sta_pers {
|
struct lq_sta_pers {
|
||||||
#ifdef CONFIG_MAC80211_DEBUGFS
|
#ifdef CONFIG_MAC80211_DEBUGFS
|
||||||
u32 dbg_fixed_rate;
|
u32 dbg_fixed_rate;
|
||||||
u8 dbg_fixed_txp_reduction;
|
u8 dbg_fixed_txp_reduction;
|
||||||
|
|
||||||
|
/* force STBC/BFER/SISO for testing */
|
||||||
|
enum rs_ss_force_opt ss_force;
|
||||||
#endif
|
#endif
|
||||||
u8 chains;
|
u8 chains;
|
||||||
s8 chain_signal[IEEE80211_MAX_CHAINS];
|
s8 chain_signal[IEEE80211_MAX_CHAINS];
|
||||||
|
Loading…
Reference in New Issue
Block a user