ath9k: Enable D3/L1 ASPM fix for AR9462

AR9462 requires this HW fix for ASPM to work properly.
Also, since WARegVal is used only for the AR8003 family,
use AR_SREV_9300_20_OR_LATER.

Signed-off-by: Sujith Manoharan <c_manoha@qca.qualcomm.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
Sujith Manoharan 2013-08-27 11:34:39 +05:30 committed by John W. Linville
parent 65c1a4de59
commit 27251e0087

View File

@ -574,18 +574,17 @@ static int __ath9k_hw_init(struct ath_hw *ah)
* We need to do this to avoid RMW of this register. We cannot * We need to do this to avoid RMW of this register. We cannot
* read the reg when chip is asleep. * read the reg when chip is asleep.
*/ */
ah->WARegVal = REG_READ(ah, AR_WA); if (AR_SREV_9300_20_OR_LATER(ah)) {
ah->WARegVal |= (AR_WA_D3_L1_DISABLE | ah->WARegVal = REG_READ(ah, AR_WA);
AR_WA_ASPM_TIMER_BASED_DISABLE); ah->WARegVal |= (AR_WA_D3_L1_DISABLE |
AR_WA_ASPM_TIMER_BASED_DISABLE);
}
if (!ath9k_hw_set_reset_reg(ah, ATH9K_RESET_POWER_ON)) { if (!ath9k_hw_set_reset_reg(ah, ATH9K_RESET_POWER_ON)) {
ath_err(common, "Couldn't reset chip\n"); ath_err(common, "Couldn't reset chip\n");
return -EIO; return -EIO;
} }
if (AR_SREV_9462(ah))
ah->WARegVal &= ~AR_WA_D3_L1_DISABLE;
if (AR_SREV_9565(ah)) { if (AR_SREV_9565(ah)) {
ah->WARegVal |= AR_WA_BIT22; ah->WARegVal |= AR_WA_BIT22;
REG_WRITE(ah, AR_WA, ah->WARegVal); REG_WRITE(ah, AR_WA, ah->WARegVal);