aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/ath9k
diff options
context:
space:
mode:
authorGabor Juhos <juhosg@openwrt.org>2009-03-06 03:08:51 -0500
committerJohn W. Linville <linville@tuxdriver.com>2009-03-16 18:09:31 -0400
commita8c96d3b225d4c9e6ff341923e3f76de401c75b2 (patch)
treee6056b9520e58fafc7db2de5152ead43e013a696 /drivers/net/wireless/ath9k
parent978b53264235eef1d2d2e9fd16ae26b3471c0b57 (diff)
ath9k: cleanup AR5416 version checking macros
Currently we have two different versions of this macros. Because they would have to do the same thing, we should simplify and merge them. Changes-licensed-under: ISC Signed-off-by: Gabor Juhos <juhosg@openwrt.org> Signed-off-by: Imre Kaloz <kaloz@openwrt.org> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/ath9k')
-rw-r--r--drivers/net/wireless/ath9k/eeprom.c16
-rw-r--r--drivers/net/wireless/ath9k/hw.c4
-rw-r--r--drivers/net/wireless/ath9k/mac.h2
-rw-r--r--drivers/net/wireless/ath9k/reg.h19
4 files changed, 22 insertions, 19 deletions
diff --git a/drivers/net/wireless/ath9k/eeprom.c b/drivers/net/wireless/ath9k/eeprom.c
index f935341bc5c4..5a5ab23a2ba2 100644
--- a/drivers/net/wireless/ath9k/eeprom.c
+++ b/drivers/net/wireless/ath9k/eeprom.c
@@ -640,7 +640,7 @@ static void ath9k_hw_get_4k_gain_boundaries_pdadcs(struct ath_hw *ah,
640 pPdGainBoundaries[i] = 640 pPdGainBoundaries[i] =
641 min((u16)AR5416_MAX_RATE_POWER, pPdGainBoundaries[i]); 641 min((u16)AR5416_MAX_RATE_POWER, pPdGainBoundaries[i]);
642 642
643 if ((i == 0) && !AR_SREV_5416_V20_OR_LATER(ah)) { 643 if ((i == 0) && !AR_SREV_5416_20_OR_LATER(ah)) {
644 minDelta = pPdGainBoundaries[0] - 23; 644 minDelta = pPdGainBoundaries[0] - 23;
645 pPdGainBoundaries[0] = 23; 645 pPdGainBoundaries[0] = 23;
646 } else { 646 } else {
@@ -755,7 +755,7 @@ static bool ath9k_hw_set_4k_power_cal_table(struct ath_hw *ah,
755 REG_RMW_FIELD(ah, AR_PHY_TPCRG1, AR_PHY_TPCRG1_PD_GAIN_3, 0); 755 REG_RMW_FIELD(ah, AR_PHY_TPCRG1, AR_PHY_TPCRG1_PD_GAIN_3, 0);
756 756
757 for (i = 0; i < AR5416_MAX_CHAINS; i++) { 757 for (i = 0; i < AR5416_MAX_CHAINS; i++) {
758 if (AR_SREV_5416_V20_OR_LATER(ah) && 758 if (AR_SREV_5416_20_OR_LATER(ah) &&
759 (ah->rxchainmask == 5 || ah->txchainmask == 5) && 759 (ah->rxchainmask == 5 || ah->txchainmask == 5) &&
760 (i != 0)) { 760 (i != 0)) {
761 regChainOffset = (i == 1) ? 0x2000 : 0x1000; 761 regChainOffset = (i == 1) ? 0x2000 : 0x1000;
@@ -771,7 +771,7 @@ static bool ath9k_hw_set_4k_power_cal_table(struct ath_hw *ah,
771 &tMinCalPower, gainBoundaries, 771 &tMinCalPower, gainBoundaries,
772 pdadcValues, numXpdGain); 772 pdadcValues, numXpdGain);
773 773
774 if ((i == 0) || AR_SREV_5416_V20_OR_LATER(ah)) { 774 if ((i == 0) || AR_SREV_5416_20_OR_LATER(ah)) {
775 REG_WRITE(ah, AR_PHY_TPCRG5 + regChainOffset, 775 REG_WRITE(ah, AR_PHY_TPCRG5 + regChainOffset,
776 SM(pdGainOverlap_t2, 776 SM(pdGainOverlap_t2,
777 AR_PHY_TPCRG5_PD_GAIN_OVERLAP) 777 AR_PHY_TPCRG5_PD_GAIN_OVERLAP)
@@ -1707,7 +1707,7 @@ static bool ath9k_hw_def_set_board_values(struct ath_hw *ah,
1707 break; 1707 break;
1708 } 1708 }
1709 1709
1710 if (AR_SREV_5416_V20_OR_LATER(ah) && 1710 if (AR_SREV_5416_20_OR_LATER(ah) &&
1711 (ah->rxchainmask == 5 || ah->txchainmask == 5) 1711 (ah->rxchainmask == 5 || ah->txchainmask == 5)
1712 && (i != 0)) 1712 && (i != 0))
1713 regChainOffset = (i == 1) ? 0x2000 : 0x1000; 1713 regChainOffset = (i == 1) ? 0x2000 : 0x1000;
@@ -1728,7 +1728,7 @@ static bool ath9k_hw_def_set_board_values(struct ath_hw *ah,
1728 SM(pModal->iqCalQCh[i], 1728 SM(pModal->iqCalQCh[i],
1729 AR_PHY_TIMING_CTRL4_IQCORR_Q_Q_COFF)); 1729 AR_PHY_TIMING_CTRL4_IQCORR_Q_Q_COFF));
1730 1730
1731 if ((i == 0) || AR_SREV_5416_V20_OR_LATER(ah)) { 1731 if ((i == 0) || AR_SREV_5416_20_OR_LATER(ah)) {
1732 if (AR5416_VER_MASK >= AR5416_EEP_MINOR_VER_3) { 1732 if (AR5416_VER_MASK >= AR5416_EEP_MINOR_VER_3) {
1733 txRxAttenLocal = pModal->txRxAttenCh[i]; 1733 txRxAttenLocal = pModal->txRxAttenCh[i];
1734 if (AR_SREV_9280_10_OR_LATER(ah)) { 1734 if (AR_SREV_9280_10_OR_LATER(ah)) {
@@ -2094,7 +2094,7 @@ static void ath9k_hw_get_def_gain_boundaries_pdadcs(struct ath_hw *ah,
2094 pPdGainBoundaries[i] = 2094 pPdGainBoundaries[i] =
2095 min((u16)AR5416_MAX_RATE_POWER, pPdGainBoundaries[i]); 2095 min((u16)AR5416_MAX_RATE_POWER, pPdGainBoundaries[i]);
2096 2096
2097 if ((i == 0) && !AR_SREV_5416_V20_OR_LATER(ah)) { 2097 if ((i == 0) && !AR_SREV_5416_20_OR_LATER(ah)) {
2098 minDelta = pPdGainBoundaries[0] - 23; 2098 minDelta = pPdGainBoundaries[0] - 23;
2099 pPdGainBoundaries[0] = 23; 2099 pPdGainBoundaries[0] = 23;
2100 } else { 2100 } else {
@@ -2228,7 +2228,7 @@ static bool ath9k_hw_set_def_power_cal_table(struct ath_hw *ah,
2228 xpdGainValues[2]); 2228 xpdGainValues[2]);
2229 2229
2230 for (i = 0; i < AR5416_MAX_CHAINS; i++) { 2230 for (i = 0; i < AR5416_MAX_CHAINS; i++) {
2231 if (AR_SREV_5416_V20_OR_LATER(ah) && 2231 if (AR_SREV_5416_20_OR_LATER(ah) &&
2232 (ah->rxchainmask == 5 || ah->txchainmask == 5) && 2232 (ah->rxchainmask == 5 || ah->txchainmask == 5) &&
2233 (i != 0)) { 2233 (i != 0)) {
2234 regChainOffset = (i == 1) ? 0x2000 : 0x1000; 2234 regChainOffset = (i == 1) ? 0x2000 : 0x1000;
@@ -2262,7 +2262,7 @@ static bool ath9k_hw_set_def_power_cal_table(struct ath_hw *ah,
2262 numXpdGain); 2262 numXpdGain);
2263 } 2263 }
2264 2264
2265 if ((i == 0) || AR_SREV_5416_V20_OR_LATER(ah)) { 2265 if ((i == 0) || AR_SREV_5416_20_OR_LATER(ah)) {
2266 if (OLC_FOR_AR9280_20_LATER) { 2266 if (OLC_FOR_AR9280_20_LATER) {
2267 REG_WRITE(ah, 2267 REG_WRITE(ah,
2268 AR_PHY_TPCRG5 + regChainOffset, 2268 AR_PHY_TPCRG5 + regChainOffset,
diff --git a/drivers/net/wireless/ath9k/hw.c b/drivers/net/wireless/ath9k/hw.c
index cdc9d15e8419..c10b33b1b673 100644
--- a/drivers/net/wireless/ath9k/hw.c
+++ b/drivers/net/wireless/ath9k/hw.c
@@ -1170,7 +1170,7 @@ static void ath9k_hw_override_ini(struct ath_hw *ah,
1170 REG_SET_BIT(ah, AR_DIAG_SW, (AR_DIAG_RX_DIS | AR_DIAG_RX_ABORT)); 1170 REG_SET_BIT(ah, AR_DIAG_SW, (AR_DIAG_RX_DIS | AR_DIAG_RX_ABORT));
1171 1171
1172 1172
1173 if (!AR_SREV_5416_V20_OR_LATER(ah) || 1173 if (!AR_SREV_5416_20_OR_LATER(ah) ||
1174 AR_SREV_9280_10_OR_LATER(ah)) 1174 AR_SREV_9280_10_OR_LATER(ah))
1175 return; 1175 return;
1176 1176
@@ -1272,7 +1272,7 @@ static int ath9k_hw_process_ini(struct ath_hw *ah,
1272 REG_WRITE(ah, AR_PHY_ADC_SERIAL_CTL, AR_PHY_SEL_EXTERNAL_RADIO); 1272 REG_WRITE(ah, AR_PHY_ADC_SERIAL_CTL, AR_PHY_SEL_EXTERNAL_RADIO);
1273 ah->eep_ops->set_addac(ah, chan); 1273 ah->eep_ops->set_addac(ah, chan);
1274 1274
1275 if (AR_SREV_5416_V22_OR_LATER(ah)) { 1275 if (AR_SREV_5416_22_OR_LATER(ah)) {
1276 REG_WRITE_ARRAY(&ah->iniAddac, 1, regWrites); 1276 REG_WRITE_ARRAY(&ah->iniAddac, 1, regWrites);
1277 } else { 1277 } else {
1278 struct ar5416IniArray temp; 1278 struct ar5416IniArray temp;
diff --git a/drivers/net/wireless/ath9k/mac.h b/drivers/net/wireless/ath9k/mac.h
index 37e3948ddc25..a75f65dae1d7 100644
--- a/drivers/net/wireless/ath9k/mac.h
+++ b/drivers/net/wireless/ath9k/mac.h
@@ -17,7 +17,7 @@
17#ifndef MAC_H 17#ifndef MAC_H
18#define MAC_H 18#define MAC_H
19 19
20#define RXSTATUS_RATE(ah, ads) (AR_SREV_5416_V20_OR_LATER(ah) ? \ 20#define RXSTATUS_RATE(ah, ads) (AR_SREV_5416_20_OR_LATER(ah) ? \
21 MS(ads->ds_rxstatus0, AR_RxRate) : \ 21 MS(ads->ds_rxstatus0, AR_RxRate) : \
22 (ads->ds_rxstatus3 >> 2) & 0xFF) 22 (ads->ds_rxstatus3 >> 2) & 0xFF)
23 23
diff --git a/drivers/net/wireless/ath9k/reg.h b/drivers/net/wireless/ath9k/reg.h
index d7b8c571e91e..0609e2e5eba8 100644
--- a/drivers/net/wireless/ath9k/reg.h
+++ b/drivers/net/wireless/ath9k/reg.h
@@ -161,10 +161,6 @@
161#define AR_SREV_VERSION_9100 0x014 161#define AR_SREV_VERSION_9100 0x014
162 162
163#define AR_SREV_9100(ah) ((ah->hw_version.macVersion) == AR_SREV_VERSION_9100) 163#define AR_SREV_9100(ah) ((ah->hw_version.macVersion) == AR_SREV_VERSION_9100)
164#define AR_SREV_5416_V20_OR_LATER(_ah) \
165 (AR_SREV_9100((_ah)) || AR_SREV_5416_20_OR_LATER(_ah))
166#define AR_SREV_5416_V22_OR_LATER(_ah) \
167 (AR_SREV_9100((_ah)) || AR_SREV_5416_22_OR_LATER(_ah))
168 164
169#define AR_ISR 0x0080 165#define AR_ISR 0x0080
170#define AR_ISR_RXOK 0x00000001 166#define AR_ISR_RXOK 0x00000001
@@ -748,12 +744,19 @@
748 744
749#define AR_SREV_9100_OR_LATER(_ah) \ 745#define AR_SREV_9100_OR_LATER(_ah) \
750 (((_ah)->hw_version.macVersion >= AR_SREV_VERSION_5416_PCIE)) 746 (((_ah)->hw_version.macVersion >= AR_SREV_VERSION_5416_PCIE))
747
748#define AR_SREV_5416(_ah) \
749 (((_ah)->hw_version.macVersion == AR_SREV_VERSION_5416_PCI) || \
750 ((_ah)->hw_version.macVersion == AR_SREV_VERSION_5416_PCIE))
751#define AR_SREV_5416_20_OR_LATER(_ah) \ 751#define AR_SREV_5416_20_OR_LATER(_ah) \
752 (((_ah)->hw_version.macVersion >= AR_SREV_VERSION_9160) || \ 752 (((AR_SREV_5416(_ah)) && \
753 ((_ah)->hw_version.macRev >= AR_SREV_REVISION_5416_20)) 753 ((_ah)->hw_version.macRev >= AR_SREV_REVISION_5416_20)) || \
754 ((_ah)->hw_version.macVersion >= AR_SREV_VERSION_9100))
754#define AR_SREV_5416_22_OR_LATER(_ah) \ 755#define AR_SREV_5416_22_OR_LATER(_ah) \
755 (((_ah)->hw_version.macVersion >= AR_SREV_VERSION_9160) || \ 756 (((AR_SREV_5416(_ah)) && \
756 ((_ah)->hw_version.macRev >= AR_SREV_REVISION_5416_22)) 757 ((_ah)->hw_version.macRev >= AR_SREV_REVISION_5416_22)) || \
758 ((_ah)->hw_version.macVersion >= AR_SREV_VERSION_9100))
759
757#define AR_SREV_9160(_ah) \ 760#define AR_SREV_9160(_ah) \
758 (((_ah)->hw_version.macVersion == AR_SREV_VERSION_9160)) 761 (((_ah)->hw_version.macVersion == AR_SREV_VERSION_9160))
759#define AR_SREV_9160_10_OR_LATER(_ah) \ 762#define AR_SREV_9160_10_OR_LATER(_ah) \