提交 b7cc9b97 编写于 作者: S Sujith Manoharan 提交者: John W. Linville

ath9k: Fix "cc_lock" usage

IRQ save/restore is not required for the cycle counters
since they are accessed only from softirq and process context.
Signed-off-by: NSujith Manoharan <c_manoha@qca.qualcomm.com>
Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
上级 0c759977
...@@ -362,10 +362,10 @@ void ath_ani_calibrate(unsigned long data) ...@@ -362,10 +362,10 @@ void ath_ani_calibrate(unsigned long data)
/* Call ANI routine if necessary */ /* Call ANI routine if necessary */
if (aniflag) { if (aniflag) {
spin_lock_irqsave(&common->cc_lock, flags); spin_lock(&common->cc_lock);
ath9k_hw_ani_monitor(ah, ah->curchan); ath9k_hw_ani_monitor(ah, ah->curchan);
ath_update_survey_stats(sc); ath_update_survey_stats(sc);
spin_unlock_irqrestore(&common->cc_lock, flags); spin_unlock(&common->cc_lock);
} }
/* Perform calibration if necessary */ /* Perform calibration if necessary */
......
...@@ -330,7 +330,6 @@ static int ath_set_channel(struct ath_softc *sc, struct cfg80211_chan_def *chand ...@@ -330,7 +330,6 @@ static int ath_set_channel(struct ath_softc *sc, struct cfg80211_chan_def *chand
struct ieee80211_hw *hw = sc->hw; struct ieee80211_hw *hw = sc->hw;
struct ath9k_channel *hchan; struct ath9k_channel *hchan;
struct ieee80211_channel *chan = chandef->chan; struct ieee80211_channel *chan = chandef->chan;
unsigned long flags;
bool offchannel; bool offchannel;
int pos = chan->hw_value; int pos = chan->hw_value;
int old_pos = -1; int old_pos = -1;
...@@ -348,9 +347,9 @@ static int ath_set_channel(struct ath_softc *sc, struct cfg80211_chan_def *chand ...@@ -348,9 +347,9 @@ static int ath_set_channel(struct ath_softc *sc, struct cfg80211_chan_def *chand
chan->center_freq, chandef->width); chan->center_freq, chandef->width);
/* update survey stats for the old channel before switching */ /* update survey stats for the old channel before switching */
spin_lock_irqsave(&common->cc_lock, flags); spin_lock_bh(&common->cc_lock);
ath_update_survey_stats(sc); ath_update_survey_stats(sc);
spin_unlock_irqrestore(&common->cc_lock, flags); spin_unlock_bh(&common->cc_lock);
ath9k_cmn_get_channel(hw, ah, chandef); ath9k_cmn_get_channel(hw, ah, chandef);
...@@ -1788,13 +1787,12 @@ static int ath9k_get_survey(struct ieee80211_hw *hw, int idx, ...@@ -1788,13 +1787,12 @@ static int ath9k_get_survey(struct ieee80211_hw *hw, int idx,
struct ath_common *common = ath9k_hw_common(sc->sc_ah); struct ath_common *common = ath9k_hw_common(sc->sc_ah);
struct ieee80211_supported_band *sband; struct ieee80211_supported_band *sband;
struct ieee80211_channel *chan; struct ieee80211_channel *chan;
unsigned long flags;
int pos; int pos;
if (config_enabled(CONFIG_ATH9K_TX99)) if (config_enabled(CONFIG_ATH9K_TX99))
return -EOPNOTSUPP; return -EOPNOTSUPP;
spin_lock_irqsave(&common->cc_lock, flags); spin_lock_bh(&common->cc_lock);
if (idx == 0) if (idx == 0)
ath_update_survey_stats(sc); ath_update_survey_stats(sc);
...@@ -1808,7 +1806,7 @@ static int ath9k_get_survey(struct ieee80211_hw *hw, int idx, ...@@ -1808,7 +1806,7 @@ static int ath9k_get_survey(struct ieee80211_hw *hw, int idx,
sband = hw->wiphy->bands[IEEE80211_BAND_5GHZ]; sband = hw->wiphy->bands[IEEE80211_BAND_5GHZ];
if (!sband || idx >= sband->n_channels) { if (!sband || idx >= sband->n_channels) {
spin_unlock_irqrestore(&common->cc_lock, flags); spin_unlock_bh(&common->cc_lock);
return -ENOENT; return -ENOENT;
} }
...@@ -1816,7 +1814,7 @@ static int ath9k_get_survey(struct ieee80211_hw *hw, int idx, ...@@ -1816,7 +1814,7 @@ static int ath9k_get_survey(struct ieee80211_hw *hw, int idx,
pos = chan->hw_value; pos = chan->hw_value;
memcpy(survey, &sc->survey[pos], sizeof(*survey)); memcpy(survey, &sc->survey[pos], sizeof(*survey));
survey->channel = chan; survey->channel = chan;
spin_unlock_irqrestore(&common->cc_lock, flags); spin_unlock_bh(&common->cc_lock);
return 0; return 0;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册