Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit a9d85fbd authored by Senthil Balasubramanian's avatar Senthil Balasubramanian Committed by John W. Linville
Browse files

ath9k_hw: Fix a reset failure on AR9382 (2x2).



AR9382 needs to be configured for the correct chain mask before
running AGC/TxIQ caliberation. Otherwise reset would fail.

Signed-off-by: default avatarSenthil Balasubramanian <senthilkumar@atheros.com>
Signed-off-by: default avatarVasanthakumar Thiagarajan <vasanth@atheros.com>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent 72a80110
Loading
Loading
Loading
Loading
+12 −5
Original line number Diff line number Diff line
@@ -718,10 +718,17 @@ static bool ar9003_hw_init_cal(struct ath_hw *ah,
			       struct ath9k_channel *chan)
{
	struct ath_common *common = ath9k_hw_common(ah);
	int val;

	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
		 * 0x7 = 0b111 , AR9003 needs to be configured for 3-chain
		 * mode before running AGC/TxIQ cals
		 */
		ar9003_hw_set_chain_masks(ah, 0x7, 0x7);

+2 −0
Original line number Diff line number Diff line
@@ -1065,6 +1065,8 @@ enum {
#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