struct ath9k_channel *chan)
 {
        struct ath_common *common = ath9k_hw_common(ah);
+       int val;
 
-       /*
-        * 0x7 = 0b111 , AR9003 needs to be configured for 3-chain mode before
-        * running AGC/TxIQ cals
-        */
-       ar9003_hw_set_chain_masks(ah, 0x7, 0x7);
+       val = REG_READ(ah, AR_ENT_OTP);
+       ath_print(common, ATH_DBG_CALIBRATE, "ath9k: AR_ENT_OTP 0x%x\n", val);
+
+       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);
 
        /* Do Tx IQ Calibration */
        ar9003_hw_tx_iq_cal(ah);
 
 #define AR_INTR_PRIO_ASYNC_MASK   0x40c8
 #define AR_INTR_PRIO_SYNC_MASK    0x40cc
 #define AR_INTR_PRIO_ASYNC_ENABLE 0x40d4
+#define AR_ENT_OTP               0x40d8
+#define AR_ENT_OTP_CHAIN2_DISABLE               0x00020000
 
 #define AR_RTC_9300_PLL_DIV          0x000003ff
 #define AR_RTC_9300_PLL_DIV_S        0