ath9k_htc: keep calibrated noise floor value for oper channel
The ath9k_hw assumes that caldata is valid only for oper channel. But with ath9k_htc case, the caldata is passed for all channels on hw_reset though we are not doing calibration on that channel. So the oper channel's nf history got cleared to default due to mismatch in channel flags. This patch also saves some space. Signed-off-by: Rajkumar Manoharan <rmanoharan@atheros.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
parent
bdd196a3e0
commit
4e3ae38738
|
@ -366,7 +366,7 @@ struct ath9k_htc_priv {
|
||||||
u16 seq_no;
|
u16 seq_no;
|
||||||
u32 bmiss_cnt;
|
u32 bmiss_cnt;
|
||||||
|
|
||||||
struct ath9k_hw_cal_data caldata[ATH9K_NUM_CHANNELS];
|
struct ath9k_hw_cal_data caldata;
|
||||||
|
|
||||||
spinlock_t beacon_lock;
|
spinlock_t beacon_lock;
|
||||||
|
|
||||||
|
|
|
@ -121,7 +121,7 @@ void ath9k_htc_reset(struct ath9k_htc_priv *priv)
|
||||||
struct ath_hw *ah = priv->ah;
|
struct ath_hw *ah = priv->ah;
|
||||||
struct ath_common *common = ath9k_hw_common(ah);
|
struct ath_common *common = ath9k_hw_common(ah);
|
||||||
struct ieee80211_channel *channel = priv->hw->conf.channel;
|
struct ieee80211_channel *channel = priv->hw->conf.channel;
|
||||||
struct ath9k_hw_cal_data *caldata;
|
struct ath9k_hw_cal_data *caldata = NULL;
|
||||||
enum htc_phymode mode;
|
enum htc_phymode mode;
|
||||||
__be16 htc_mode;
|
__be16 htc_mode;
|
||||||
u8 cmd_rsp;
|
u8 cmd_rsp;
|
||||||
|
@ -139,7 +139,7 @@ void ath9k_htc_reset(struct ath9k_htc_priv *priv)
|
||||||
WMI_CMD(WMI_DRAIN_TXQ_ALL_CMDID);
|
WMI_CMD(WMI_DRAIN_TXQ_ALL_CMDID);
|
||||||
WMI_CMD(WMI_STOP_RECV_CMDID);
|
WMI_CMD(WMI_STOP_RECV_CMDID);
|
||||||
|
|
||||||
caldata = &priv->caldata[channel->hw_value];
|
caldata = &priv->caldata;
|
||||||
ret = ath9k_hw_reset(ah, ah->curchan, caldata, false);
|
ret = ath9k_hw_reset(ah, ah->curchan, caldata, false);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
ath_err(common,
|
ath_err(common,
|
||||||
|
@ -202,7 +202,8 @@ static int ath9k_htc_set_channel(struct ath9k_htc_priv *priv,
|
||||||
channel->center_freq, conf_is_ht(conf), conf_is_ht40(conf),
|
channel->center_freq, conf_is_ht(conf), conf_is_ht40(conf),
|
||||||
fastcc);
|
fastcc);
|
||||||
|
|
||||||
caldata = &priv->caldata[channel->hw_value];
|
if (!fastcc)
|
||||||
|
caldata = &priv->caldata;
|
||||||
ret = ath9k_hw_reset(ah, hchan, caldata, fastcc);
|
ret = ath9k_hw_reset(ah, hchan, caldata, fastcc);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
ath_err(common,
|
ath_err(common,
|
||||||
|
|
Loading…
Reference in New Issue