ath9k_hw: Clean up rx/tx chain configuration before AGC/IQ cal
authorVasanthakumar Thiagarajan <vasanth@atheros.com>
Tue, 19 Apr 2011 13:59:09 +0000 (19:29 +0530)
committerJohn W. Linville <linville@tuxdriver.com>
Mon, 25 Apr 2011 18:50:10 +0000 (14:50 -0400)
Use hw supported chains instead of hard coded values.

Signed-off-by: Vasanthakumar Thiagarajan <vasanth@atheros.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
drivers/net/wireless/ath/ath9k/ar9003_calib.c

index 4a4cd88429c069076945e3d0c13807c8d83b2729..09f3aa7f82f5e36a77bd8c8b07eefe39c5f0efe8 100644 (file)
@@ -940,21 +940,18 @@ static bool ar9003_hw_init_cal(struct ath_hw *ah,
                               struct ath9k_channel *chan)
 {
        struct ath_common *common = ath9k_hw_common(ah);
+       struct ath9k_hw_capabilities *pCap = &ah->caps;
        int val;
 
        val = REG_READ(ah, AR_ENT_OTP);
        ath_dbg(common, ATH_DBG_CALIBRATE, "ath9k: AR_ENT_OTP 0x%x\n", val);
 
-       if (AR_SREV_9485(ah))
-               ar9003_hw_set_chain_masks(ah, 0x1, 0x1);
-       else if (val & AR_ENT_OTP_CHAIN2_DISABLE)
+       /* Configure rx/tx chains before running AGC/TxiQ cals */
+       if (val & AR_ENT_OTP_CHAIN2_DISABLE)
                ar9003_hw_set_chain_masks(ah, 0x3, 0x3);
        else
-               /*
-                * 0x7 = 0b111 , AR9003 needs to be configured for 3-chain
-                * mode before running AGC/TxIQ cals
-                */
-               ar9003_hw_set_chain_masks(ah, 0x7, 0x7);
+               ar9003_hw_set_chain_masks(ah, pCap->rx_chainmask,
+                                         pCap->tx_chainmask);
 
        /* Do Tx IQ Calibration */
        if (AR_SREV_9485(ah))