aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net')
-rw-r--r--drivers/net/wireless/ath9k/hw.c33
1 files changed, 21 insertions, 12 deletions
diff --git a/drivers/net/wireless/ath9k/hw.c b/drivers/net/wireless/ath9k/hw.c
index 62e44a0ef996..372ae61c7b17 100644
--- a/drivers/net/wireless/ath9k/hw.c
+++ b/drivers/net/wireless/ath9k/hw.c
@@ -5867,7 +5867,6 @@ bool ath9k_hw_reset(struct ath_hal *ah,
5867 bool bChannelChange, 5867 bool bChannelChange,
5868 int *status) 5868 int *status)
5869{ 5869{
5870#define FAIL(_code) do { ecode = _code; goto bad; } while (0)
5871 u32 saveLedState; 5870 u32 saveLedState;
5872 struct ath_hal_5416 *ahp = AH5416(ah); 5871 struct ath_hal_5416 *ahp = AH5416(ah);
5873 struct ath9k_channel *curchan = ah->ah_curchan; 5872 struct ath9k_channel *curchan = ah->ah_curchan;
@@ -5889,7 +5888,8 @@ bool ath9k_hw_reset(struct ath_hal *ah,
5889 DPRINTF(ah->ah_sc, ATH_DBG_CHANNEL, 5888 DPRINTF(ah->ah_sc, ATH_DBG_CHANNEL,
5890 "%s: invalid channel %u/0x%x; no mapping\n", 5889 "%s: invalid channel %u/0x%x; no mapping\n",
5891 __func__, chan->channel, chan->channelFlags); 5890 __func__, chan->channel, chan->channelFlags);
5892 FAIL(-EINVAL); 5891 ecode = -EINVAL;
5892 goto bad;
5893 } 5893 }
5894 5894
5895 if (!ath9k_hw_setpower(ah, ATH9K_PM_AWAKE)) 5895 if (!ath9k_hw_setpower(ah, ATH9K_PM_AWAKE))
@@ -5930,7 +5930,8 @@ bool ath9k_hw_reset(struct ath_hal *ah,
5930 if (!ath9k_hw_chip_reset(ah, chan)) { 5930 if (!ath9k_hw_chip_reset(ah, chan)) {
5931 DPRINTF(ah->ah_sc, ATH_DBG_RESET, "%s: chip reset failed\n", 5931 DPRINTF(ah->ah_sc, ATH_DBG_RESET, "%s: chip reset failed\n",
5932 __func__); 5932 __func__);
5933 FAIL(-EIO); 5933 ecode = -EINVAL;
5934 goto bad;
5934 } 5935 }
5935 5936
5936 if (AR_SREV_9280(ah)) { 5937 if (AR_SREV_9280(ah)) {
@@ -5947,8 +5948,10 @@ bool ath9k_hw_reset(struct ath_hal *ah,
5947 } 5948 }
5948 5949
5949 ecode = ath9k_hw_process_ini(ah, chan, macmode); 5950 ecode = ath9k_hw_process_ini(ah, chan, macmode);
5950 if (ecode != 0) 5951 if (ecode != 0) {
5952 ecode = -EINVAL;
5951 goto bad; 5953 goto bad;
5954 }
5952 5955
5953 if (IS_CHAN_OFDM(chan) || IS_CHAN_HT(chan)) 5956 if (IS_CHAN_OFDM(chan) || IS_CHAN_HT(chan))
5954 ath9k_hw_set_delta_slope(ah, chan); 5957 ath9k_hw_set_delta_slope(ah, chan);
@@ -5961,7 +5964,8 @@ bool ath9k_hw_reset(struct ath_hal *ah,
5961 if (!ath9k_hw_eeprom_set_board_values(ah, chan)) { 5964 if (!ath9k_hw_eeprom_set_board_values(ah, chan)) {
5962 DPRINTF(ah->ah_sc, ATH_DBG_EEPROM, 5965 DPRINTF(ah->ah_sc, ATH_DBG_EEPROM,
5963 "%s: error setting board options\n", __func__); 5966 "%s: error setting board options\n", __func__);
5964 FAIL(-EIO); 5967 ecode = -EIO;
5968 goto bad;
5965 } 5969 }
5966 5970
5967 ath9k_hw_decrease_chain_power(ah, chan); 5971 ath9k_hw_decrease_chain_power(ah, chan);
@@ -5989,11 +5993,15 @@ bool ath9k_hw_reset(struct ath_hal *ah,
5989 REG_WRITE(ah, AR_RSSI_THR, INIT_RSSI_THR); 5993 REG_WRITE(ah, AR_RSSI_THR, INIT_RSSI_THR);
5990 5994
5991 if (AR_SREV_9280_10_OR_LATER(ah)) { 5995 if (AR_SREV_9280_10_OR_LATER(ah)) {
5992 if (!(ath9k_hw_ar9280_set_channel(ah, chan))) 5996 if (!(ath9k_hw_ar9280_set_channel(ah, chan))) {
5993 FAIL(-EIO); 5997 ecode = -EIO;
5998 goto bad;
5999 }
5994 } else { 6000 } else {
5995 if (!(ath9k_hw_set_channel(ah, chan))) 6001 if (!(ath9k_hw_set_channel(ah, chan))) {
5996 FAIL(-EIO); 6002 ecode = -EIO;
6003 goto bad;
6004 }
5997 } 6005 }
5998 6006
5999 for (i = 0; i < AR_NUM_DCU; i++) 6007 for (i = 0; i < AR_NUM_DCU; i++)
@@ -6027,8 +6035,10 @@ bool ath9k_hw_reset(struct ath_hal *ah,
6027 6035
6028 ath9k_hw_init_bb(ah, chan); 6036 ath9k_hw_init_bb(ah, chan);
6029 6037
6030 if (!ath9k_hw_init_cal(ah, chan)) 6038 if (!ath9k_hw_init_cal(ah, chan)){
6031 FAIL(-ENODEV); 6039 ecode = -EIO;;
6040 goto bad;
6041 }
6032 6042
6033 rx_chainmask = ahp->ah_rxchainmask; 6043 rx_chainmask = ahp->ah_rxchainmask;
6034 if ((rx_chainmask == 0x5) || (rx_chainmask == 0x3)) { 6044 if ((rx_chainmask == 0x5) || (rx_chainmask == 0x3)) {
@@ -6064,7 +6074,6 @@ bad:
6064 if (status) 6074 if (status)
6065 *status = ecode; 6075 *status = ecode;
6066 return false; 6076 return false;
6067#undef FAIL
6068} 6077}
6069 6078
6070bool ath9k_hw_phy_disable(struct ath_hal *ah) 6079bool ath9k_hw_phy_disable(struct ath_hal *ah)