diff options
author | Sujith <Sujith.Manoharan@atheros.com> | 2008-08-07 01:22:38 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2008-08-07 09:49:43 -0400 |
commit | 60b67f519213cf6d59236d065b0953962b56abca (patch) | |
tree | 3af58f097b3899aea9b525c563626930c4cab4b4 /drivers/net/wireless/ath9k | |
parent | b08cbcd4546445740c2a04291204b56f8baf7be2 (diff) |
ath9k: Cleanup data structures related to HW capabilities
Signed-off-by: Sujith Manoharan <Sujith.Manoharan@atheros.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/ath9k')
-rw-r--r-- | drivers/net/wireless/ath9k/ath9k.h | 183 | ||||
-rw-r--r-- | drivers/net/wireless/ath9k/beacon.c | 10 | ||||
-rw-r--r-- | drivers/net/wireless/ath9k/core.c | 58 | ||||
-rw-r--r-- | drivers/net/wireless/ath9k/hw.c | 369 | ||||
-rw-r--r-- | drivers/net/wireless/ath9k/main.c | 6 | ||||
-rw-r--r-- | drivers/net/wireless/ath9k/rc.c | 2 | ||||
-rw-r--r-- | drivers/net/wireless/ath9k/recv.c | 4 | ||||
-rw-r--r-- | drivers/net/wireless/ath9k/regd.c | 14 | ||||
-rw-r--r-- | drivers/net/wireless/ath9k/xmit.c | 4 |
9 files changed, 330 insertions, 320 deletions
diff --git a/drivers/net/wireless/ath9k/ath9k.h b/drivers/net/wireless/ath9k/ath9k.h index dc1da64d2d7c..71027dcdcafc 100644 --- a/drivers/net/wireless/ath9k/ath9k.h +++ b/drivers/net/wireless/ath9k/ath9k.h | |||
@@ -147,94 +147,95 @@ struct ath_desc { | |||
147 | 147 | ||
148 | #define ATH9K_RXDESC_INTREQ 0x0020 | 148 | #define ATH9K_RXDESC_INTREQ 0x0020 |
149 | 149 | ||
150 | enum hal_capability_type { | 150 | enum ath9k_hw_caps { |
151 | HAL_CAP_CIPHER = 0, | 151 | ATH9K_HW_CAP_CHAN_SPREAD = BIT(0), |
152 | HAL_CAP_TKIP_MIC, | 152 | ATH9K_HW_CAP_MIC_AESCCM = BIT(1), |
153 | HAL_CAP_TKIP_SPLIT, | 153 | ATH9K_HW_CAP_MIC_CKIP = BIT(2), |
154 | HAL_CAP_PHYCOUNTERS, | 154 | ATH9K_HW_CAP_MIC_TKIP = BIT(3), |
155 | HAL_CAP_DIVERSITY, | 155 | ATH9K_HW_CAP_CIPHER_AESCCM = BIT(4), |
156 | HAL_CAP_PSPOLL, | 156 | ATH9K_HW_CAP_CIPHER_CKIP = BIT(5), |
157 | HAL_CAP_TXPOW, | 157 | ATH9K_HW_CAP_CIPHER_TKIP = BIT(6), |
158 | HAL_CAP_PHYDIAG, | 158 | ATH9K_HW_CAP_VEOL = BIT(7), |
159 | HAL_CAP_MCAST_KEYSRCH, | 159 | ATH9K_HW_CAP_BSSIDMASK = BIT(8), |
160 | HAL_CAP_TSF_ADJUST, | 160 | ATH9K_HW_CAP_MCAST_KEYSEARCH = BIT(9), |
161 | HAL_CAP_WME_TKIPMIC, | 161 | ATH9K_HW_CAP_CHAN_HALFRATE = BIT(10), |
162 | HAL_CAP_RFSILENT, | 162 | ATH9K_HW_CAP_CHAN_QUARTERRATE = BIT(11), |
163 | HAL_CAP_ANT_CFG_2GHZ, | 163 | ATH9K_HW_CAP_HT = BIT(12), |
164 | HAL_CAP_ANT_CFG_5GHZ | 164 | ATH9K_HW_CAP_GTT = BIT(13), |
165 | ATH9K_HW_CAP_FASTCC = BIT(14), | ||
166 | ATH9K_HW_CAP_RFSILENT = BIT(15), | ||
167 | ATH9K_HW_CAP_WOW = BIT(16), | ||
168 | ATH9K_HW_CAP_CST = BIT(17), | ||
169 | ATH9K_HW_CAP_ENHANCEDPM = BIT(18), | ||
170 | ATH9K_HW_CAP_AUTOSLEEP = BIT(19), | ||
171 | ATH9K_HW_CAP_4KB_SPLITTRANS = BIT(20), | ||
172 | ATH9K_HW_CAP_WOW_MATCHPATTERN_EXACT = BIT(21), | ||
165 | }; | 173 | }; |
166 | 174 | ||
167 | struct hal_capabilities { | 175 | enum ath9k_capability_type { |
168 | u32 halChanSpreadSupport:1, | 176 | ATH9K_CAP_CIPHER = 0, |
169 | halChapTuningSupport:1, | 177 | ATH9K_CAP_TKIP_MIC, |
170 | halMicAesCcmSupport:1, | 178 | ATH9K_CAP_TKIP_SPLIT, |
171 | halMicCkipSupport:1, | 179 | ATH9K_CAP_PHYCOUNTERS, |
172 | halMicTkipSupport:1, | 180 | ATH9K_CAP_DIVERSITY, |
173 | halCipherAesCcmSupport:1, | 181 | ATH9K_CAP_TXPOW, |
174 | halCipherCkipSupport:1, | 182 | ATH9K_CAP_PHYDIAG, |
175 | halCipherTkipSupport:1, | 183 | ATH9K_CAP_MCAST_KEYSRCH, |
176 | halVEOLSupport:1, | 184 | ATH9K_CAP_TSF_ADJUST, |
177 | halBssIdMaskSupport:1, | 185 | ATH9K_CAP_WME_TKIPMIC, |
178 | halMcastKeySrchSupport:1, | 186 | ATH9K_CAP_RFSILENT, |
179 | halTsfAddSupport:1, | 187 | ATH9K_CAP_ANT_CFG_2GHZ, |
180 | halChanHalfRate:1, | 188 | ATH9K_CAP_ANT_CFG_5GHZ |
181 | halChanQuarterRate:1, | ||
182 | halHTSupport:1, | ||
183 | halGTTSupport:1, | ||
184 | halFastCCSupport:1, | ||
185 | halRfSilentSupport:1, | ||
186 | halWowSupport:1, | ||
187 | halCSTSupport:1, | ||
188 | halEnhancedPmSupport:1, | ||
189 | halAutoSleepSupport:1, | ||
190 | hal4kbSplitTransSupport:1, | ||
191 | halWowMatchPatternExact:1; | ||
192 | u32 halWirelessModes; | ||
193 | u16 halTotalQueues; | ||
194 | u16 halKeyCacheSize; | ||
195 | u16 halLow5GhzChan, halHigh5GhzChan; | ||
196 | u16 halLow2GhzChan, halHigh2GhzChan; | ||
197 | u16 halNumMRRetries; | ||
198 | u16 halRtsAggrLimit; | ||
199 | u8 halTxChainMask; | ||
200 | u8 halRxChainMask; | ||
201 | u16 halTxTrigLevelMax; | ||
202 | u16 halRegCap; | ||
203 | u8 halNumGpioPins; | ||
204 | u8 halNumAntCfg2GHz; | ||
205 | u8 halNumAntCfg5GHz; | ||
206 | }; | 189 | }; |
207 | 190 | ||
208 | struct hal_ops_config { | 191 | struct ath9k_hw_capabilities { |
209 | int ath_hal_dma_beacon_response_time; | 192 | u32 hw_caps; /* ATH9K_HW_CAP_* from ath9k_hw_caps */ |
210 | int ath_hal_sw_beacon_response_time; | 193 | u32 wireless_modes; |
211 | int ath_hal_additional_swba_backoff; | 194 | u16 total_queues; |
212 | int ath_hal_6mb_ack; | 195 | u16 keycache_size; |
213 | int ath_hal_cwmIgnoreExtCCA; | 196 | u16 low_5ghz_chan, high_5ghz_chan; |
214 | u8 ath_hal_pciePowerSaveEnable; | 197 | u16 low_2ghz_chan, high_2ghz_chan; |
215 | u8 ath_hal_pcieL1SKPEnable; | 198 | u16 num_mr_retries; |
216 | u8 ath_hal_pcieClockReq; | 199 | u16 rts_aggr_limit; |
217 | u32 ath_hal_pcieWaen; | 200 | u8 tx_chainmask; |
218 | int ath_hal_pciePowerReset; | 201 | u8 rx_chainmask; |
219 | u8 ath_hal_pcieRestore; | 202 | u16 tx_triglevel_max; |
220 | u8 ath_hal_analogShiftReg; | 203 | u16 reg_cap; |
221 | u8 ath_hal_htEnable; | 204 | u8 num_gpio_pins; |
222 | u32 ath_hal_ofdmTrigLow; | 205 | u8 num_antcfg_2ghz; |
223 | u32 ath_hal_ofdmTrigHigh; | 206 | u8 num_antcfg_5ghz; |
224 | u32 ath_hal_cckTrigHigh; | 207 | }; |
225 | u32 ath_hal_cckTrigLow; | 208 | |
226 | u32 ath_hal_enableANI; | 209 | struct ath9k_ops_config { |
227 | u8 ath_hal_noiseImmunityLvl; | 210 | int dma_beacon_response_time; |
228 | u32 ath_hal_ofdmWeakSigDet; | 211 | int sw_beacon_response_time; |
229 | u32 ath_hal_cckWeakSigThr; | 212 | int additional_swba_backoff; |
230 | u8 ath_hal_spurImmunityLvl; | 213 | int ack_6mb; |
231 | u8 ath_hal_firStepLvl; | 214 | int cwm_ignore_extcca; |
232 | int8_t ath_hal_rssiThrHigh; | 215 | u8 pcie_powersave_enable; |
233 | int8_t ath_hal_rssiThrLow; | 216 | u8 pcie_l1skp_enable; |
234 | u16 ath_hal_diversityControl; | 217 | u8 pcie_clock_req; |
235 | u16 ath_hal_antennaSwitchSwap; | 218 | u32 pcie_waen; |
236 | int ath_hal_serializeRegMode; | 219 | int pcie_power_reset; |
237 | int ath_hal_intrMitigation; | 220 | u8 pcie_restore; |
221 | u8 analog_shiftreg; | ||
222 | u8 ht_enable; | ||
223 | u32 ofdm_trig_low; | ||
224 | u32 ofdm_trig_high; | ||
225 | u32 cck_trig_high; | ||
226 | u32 cck_trig_low; | ||
227 | u32 enable_ani; | ||
228 | u8 noise_immunity_level; | ||
229 | u32 ofdm_weaksignal_det; | ||
230 | u32 cck_weaksignal_thr; | ||
231 | u8 spur_immunity_level; | ||
232 | u8 firstep_level; | ||
233 | int8_t rssi_thr_high; | ||
234 | int8_t rssi_thr_low; | ||
235 | u16 diversity_control; | ||
236 | u16 antenna_switch_swap; | ||
237 | int serialize_regmode; | ||
238 | int intr_mitigation; | ||
238 | #define SPUR_DISABLE 0 | 239 | #define SPUR_DISABLE 0 |
239 | #define SPUR_ENABLE_IOCTL 1 | 240 | #define SPUR_ENABLE_IOCTL 1 |
240 | #define SPUR_ENABLE_EEPROM 2 | 241 | #define SPUR_ENABLE_EEPROM 2 |
@@ -246,8 +247,8 @@ struct hal_ops_config { | |||
246 | #define AR_BASE_FREQ_5GHZ 4900 | 247 | #define AR_BASE_FREQ_5GHZ 4900 |
247 | #define AR_SPUR_FEEQ_BOUND_HT40 19 | 248 | #define AR_SPUR_FEEQ_BOUND_HT40 19 |
248 | #define AR_SPUR_FEEQ_BOUND_HT20 10 | 249 | #define AR_SPUR_FEEQ_BOUND_HT20 10 |
249 | int ath_hal_spurMode; | 250 | int spurmode; |
250 | u16 ath_hal_spurChans[AR_EEPROM_MODAL_SPURS][2]; | 251 | u16 spurchans[AR_EEPROM_MODAL_SPURS][2]; |
251 | }; | 252 | }; |
252 | 253 | ||
253 | enum ath9k_tx_queue { | 254 | enum ath9k_tx_queue { |
@@ -815,8 +816,8 @@ struct ath_hal { | |||
815 | u8 ah_decompMask[ATH9K_DECOMP_MASK_SIZE]; | 816 | u8 ah_decompMask[ATH9K_DECOMP_MASK_SIZE]; |
816 | u32 ah_flags; | 817 | u32 ah_flags; |
817 | enum ath9k_opmode ah_opmode; | 818 | enum ath9k_opmode ah_opmode; |
818 | struct hal_ops_config ah_config; | 819 | struct ath9k_ops_config ah_config; |
819 | struct hal_capabilities ah_caps; | 820 | struct ath9k_hw_capabilities ah_caps; |
820 | int16_t ah_powerLimit; | 821 | int16_t ah_powerLimit; |
821 | u16 ah_maxPowerLevel; | 822 | u16 ah_maxPowerLevel; |
822 | u32 ah_tpScale; | 823 | u32 ah_tpScale; |
@@ -878,7 +879,7 @@ struct chan_centers { | |||
878 | }; | 879 | }; |
879 | 880 | ||
880 | int ath_hal_getcapability(struct ath_hal *ah, | 881 | int ath_hal_getcapability(struct ath_hal *ah, |
881 | enum hal_capability_type type, | 882 | enum ath9k_capability_type type, |
882 | u32 capability, | 883 | u32 capability, |
883 | u32 *result); | 884 | u32 *result); |
884 | const struct ath9k_rate_table *ath9k_hw_getratetable(struct ath_hal *ah, | 885 | const struct ath9k_rate_table *ath9k_hw_getratetable(struct ath_hal *ah, |
@@ -947,11 +948,11 @@ void ath9k_hw_set11nmac2040(struct ath_hal *ah, enum ath9k_ht_macmode mode); | |||
947 | bool ath9k_hw_phycounters(struct ath_hal *ah); | 948 | bool ath9k_hw_phycounters(struct ath_hal *ah); |
948 | bool ath9k_hw_keyreset(struct ath_hal *ah, u16 entry); | 949 | bool ath9k_hw_keyreset(struct ath_hal *ah, u16 entry); |
949 | bool ath9k_hw_getcapability(struct ath_hal *ah, | 950 | bool ath9k_hw_getcapability(struct ath_hal *ah, |
950 | enum hal_capability_type type, | 951 | enum ath9k_capability_type type, |
951 | u32 capability, | 952 | u32 capability, |
952 | u32 *result); | 953 | u32 *result); |
953 | bool ath9k_hw_setcapability(struct ath_hal *ah, | 954 | bool ath9k_hw_setcapability(struct ath_hal *ah, |
954 | enum hal_capability_type type, | 955 | enum ath9k_capability_type type, |
955 | u32 capability, | 956 | u32 capability, |
956 | u32 setting, | 957 | u32 setting, |
957 | int *status); | 958 | int *status); |
diff --git a/drivers/net/wireless/ath9k/beacon.c b/drivers/net/wireless/ath9k/beacon.c index 00993f828c5c..ba3dd253e963 100644 --- a/drivers/net/wireless/ath9k/beacon.c +++ b/drivers/net/wireless/ath9k/beacon.c | |||
@@ -85,7 +85,8 @@ static void ath_beacon_setup(struct ath_softc *sc, | |||
85 | 85 | ||
86 | flags = ATH9K_TXDESC_NOACK; | 86 | flags = ATH9K_TXDESC_NOACK; |
87 | 87 | ||
88 | if (sc->sc_opmode == ATH9K_M_IBSS && ah->ah_caps.halVEOLSupport) { | 88 | if (sc->sc_opmode == ATH9K_M_IBSS && |
89 | (ah->ah_caps.hw_caps & ATH9K_HW_CAP_VEOL)) { | ||
89 | ds->ds_link = bf->bf_daddr; /* self-linked */ | 90 | ds->ds_link = bf->bf_daddr; /* self-linked */ |
90 | flags |= ATH9K_TXDESC_VEOL; | 91 | flags |= ATH9K_TXDESC_VEOL; |
91 | /* Let hardware handle antenna switching. */ | 92 | /* Let hardware handle antenna switching. */ |
@@ -375,7 +376,7 @@ int ath_beacon_alloc(struct ath_softc *sc, int if_id) | |||
375 | list_del(&avp->av_bcbuf->list); | 376 | list_del(&avp->av_bcbuf->list); |
376 | 377 | ||
377 | if (sc->sc_opmode == ATH9K_M_HOSTAP || | 378 | if (sc->sc_opmode == ATH9K_M_HOSTAP || |
378 | !sc->sc_ah->ah_caps.halVEOLSupport) { | 379 | !(sc->sc_ah->ah_caps.hw_caps & ATH9K_HW_CAP_VEOL)) { |
379 | int slot; | 380 | int slot; |
380 | /* | 381 | /* |
381 | * Assign the vap to a beacon xmit slot. As | 382 | * Assign the vap to a beacon xmit slot. As |
@@ -939,7 +940,7 @@ void ath_beacon_config(struct ath_softc *sc, int if_id) | |||
939 | * deal with things. | 940 | * deal with things. |
940 | */ | 941 | */ |
941 | intval |= ATH9K_BEACON_ENA; | 942 | intval |= ATH9K_BEACON_ENA; |
942 | if (!ah->ah_caps.halVEOLSupport) | 943 | if (!(ah->ah_caps.hw_caps & ATH9K_HW_CAP_VEOL)) |
943 | sc->sc_imask |= ATH9K_INT_SWBA; | 944 | sc->sc_imask |= ATH9K_INT_SWBA; |
944 | ath_beaconq_config(sc); | 945 | ath_beaconq_config(sc); |
945 | } else if (sc->sc_opmode == ATH9K_M_HOSTAP) { | 946 | } else if (sc->sc_opmode == ATH9K_M_HOSTAP) { |
@@ -958,7 +959,8 @@ void ath_beacon_config(struct ath_softc *sc, int if_id) | |||
958 | * When using a self-linked beacon descriptor in | 959 | * When using a self-linked beacon descriptor in |
959 | * ibss mode load it once here. | 960 | * ibss mode load it once here. |
960 | */ | 961 | */ |
961 | if (sc->sc_opmode == ATH9K_M_IBSS && ah->ah_caps.halVEOLSupport) | 962 | if (sc->sc_opmode == ATH9K_M_IBSS && |
963 | (ah->ah_caps.hw_caps & ATH9K_HW_CAP_VEOL)) | ||
962 | ath_beacon_start_adhoc(sc, 0); | 964 | ath_beacon_start_adhoc(sc, 0); |
963 | } | 965 | } |
964 | #undef TSF_TO_TU | 966 | #undef TSF_TO_TU |
diff --git a/drivers/net/wireless/ath9k/core.c b/drivers/net/wireless/ath9k/core.c index e8b3f1fabb31..f7bf0783f3be 100644 --- a/drivers/net/wireless/ath9k/core.c +++ b/drivers/net/wireless/ath9k/core.c | |||
@@ -536,7 +536,7 @@ int ath_chainmask_sel_logic(struct ath_softc *sc, struct ath_node *an) | |||
536 | * sc_chainmask_auto_sel is used for internal global auto-switching | 536 | * sc_chainmask_auto_sel is used for internal global auto-switching |
537 | * enabled/disabled setting | 537 | * enabled/disabled setting |
538 | */ | 538 | */ |
539 | if (sc->sc_ah->ah_caps.halTxChainMask != ATH_CHAINMASK_SEL_3X3) { | 539 | if (sc->sc_ah->ah_caps.tx_chainmask != ATH_CHAINMASK_SEL_3X3) { |
540 | cm->cur_tx_mask = sc->sc_tx_chainmask; | 540 | cm->cur_tx_mask = sc->sc_tx_chainmask; |
541 | return cm->cur_tx_mask; | 541 | return cm->cur_tx_mask; |
542 | } | 542 | } |
@@ -580,8 +580,8 @@ void ath_update_chainmask(struct ath_softc *sc, int is_ht) | |||
580 | { | 580 | { |
581 | sc->sc_update_chainmask = 1; | 581 | sc->sc_update_chainmask = 1; |
582 | if (is_ht) { | 582 | if (is_ht) { |
583 | sc->sc_tx_chainmask = sc->sc_ah->ah_caps.halTxChainMask; | 583 | sc->sc_tx_chainmask = sc->sc_ah->ah_caps.tx_chainmask; |
584 | sc->sc_rx_chainmask = sc->sc_ah->ah_caps.halRxChainMask; | 584 | sc->sc_rx_chainmask = sc->sc_ah->ah_caps.rx_chainmask; |
585 | } else { | 585 | } else { |
586 | sc->sc_tx_chainmask = 1; | 586 | sc->sc_tx_chainmask = 1; |
587 | sc->sc_rx_chainmask = 1; | 587 | sc->sc_rx_chainmask = 1; |
@@ -780,8 +780,8 @@ int ath_open(struct ath_softc *sc, struct ath9k_channel *initial_chan) | |||
780 | ath_stop(sc); | 780 | ath_stop(sc); |
781 | 781 | ||
782 | /* Initialize chanmask selection */ | 782 | /* Initialize chanmask selection */ |
783 | sc->sc_tx_chainmask = ah->ah_caps.halTxChainMask; | 783 | sc->sc_tx_chainmask = ah->ah_caps.tx_chainmask; |
784 | sc->sc_rx_chainmask = ah->ah_caps.halRxChainMask; | 784 | sc->sc_rx_chainmask = ah->ah_caps.rx_chainmask; |
785 | 785 | ||
786 | /* Reset SERDES registers */ | 786 | /* Reset SERDES registers */ |
787 | ath9k_hw_configpcipowersave(ah, 0); | 787 | ath9k_hw_configpcipowersave(ah, 0); |
@@ -832,10 +832,10 @@ int ath_open(struct ath_softc *sc, struct ath9k_channel *initial_chan) | |||
832 | | ATH9K_INT_RXEOL | ATH9K_INT_RXORN | 832 | | ATH9K_INT_RXEOL | ATH9K_INT_RXORN |
833 | | ATH9K_INT_FATAL | ATH9K_INT_GLOBAL; | 833 | | ATH9K_INT_FATAL | ATH9K_INT_GLOBAL; |
834 | 834 | ||
835 | if (ah->ah_caps.halGTTSupport) | 835 | if (ah->ah_caps.hw_caps & ATH9K_HW_CAP_GTT) |
836 | sc->sc_imask |= ATH9K_INT_GTT; | 836 | sc->sc_imask |= ATH9K_INT_GTT; |
837 | 837 | ||
838 | if (ah->ah_caps.halHTSupport) | 838 | if (ah->ah_caps.hw_caps & ATH9K_HW_CAP_HT) |
839 | sc->sc_imask |= ATH9K_INT_CST; | 839 | sc->sc_imask |= ATH9K_INT_CST; |
840 | 840 | ||
841 | /* | 841 | /* |
@@ -851,8 +851,9 @@ int ath_open(struct ath_softc *sc, struct ath9k_channel *initial_chan) | |||
851 | * that does, if not overridden by configuration, | 851 | * that does, if not overridden by configuration, |
852 | * enable the TIM interrupt when operating as station. | 852 | * enable the TIM interrupt when operating as station. |
853 | */ | 853 | */ |
854 | if (ah->ah_caps.halEnhancedPmSupport && sc->sc_opmode == ATH9K_M_STA && | 854 | if ((ah->ah_caps.hw_caps & ATH9K_HW_CAP_ENHANCEDPM) && |
855 | !sc->sc_config.swBeaconProcess) | 855 | (sc->sc_opmode == ATH9K_M_STA) && |
856 | !sc->sc_config.swBeaconProcess) | ||
856 | sc->sc_imask |= ATH9K_INT_TIM; | 857 | sc->sc_imask |= ATH9K_INT_TIM; |
857 | /* | 858 | /* |
858 | * Don't enable interrupts here as we've not yet built our | 859 | * Don't enable interrupts here as we've not yet built our |
@@ -1061,7 +1062,8 @@ irqreturn_t ath_isr(int irq, void *dev) | |||
1061 | ath9k_hw_set_interrupts(ah, sc->sc_imask); | 1062 | ath9k_hw_set_interrupts(ah, sc->sc_imask); |
1062 | } | 1063 | } |
1063 | if (status & ATH9K_INT_TIM_TIMER) { | 1064 | if (status & ATH9K_INT_TIM_TIMER) { |
1064 | if (!ah->ah_caps.halAutoSleepSupport) { | 1065 | if (!(ah->ah_caps.hw_caps & |
1066 | ATH9K_HW_CAP_AUTOSLEEP)) { | ||
1065 | /* Clear RxAbort bit so that we can | 1067 | /* Clear RxAbort bit so that we can |
1066 | * receive frames */ | 1068 | * receive frames */ |
1067 | ath9k_hw_setrxabort(ah, 0); | 1069 | ath9k_hw_setrxabort(ah, 0); |
@@ -1166,10 +1168,10 @@ int ath_init(u16 devid, struct ath_softc *sc) | |||
1166 | sc->sc_ah = ah; | 1168 | sc->sc_ah = ah; |
1167 | 1169 | ||
1168 | /* Get the chipset-specific aggr limit. */ | 1170 | /* Get the chipset-specific aggr limit. */ |
1169 | sc->sc_rtsaggrlimit = ah->ah_caps.halRtsAggrLimit; | 1171 | sc->sc_rtsaggrlimit = ah->ah_caps.rts_aggr_limit; |
1170 | 1172 | ||
1171 | /* Get the hardware key cache size. */ | 1173 | /* Get the hardware key cache size. */ |
1172 | sc->sc_keymax = ah->ah_caps.halKeyCacheSize; | 1174 | sc->sc_keymax = ah->ah_caps.keycache_size; |
1173 | if (sc->sc_keymax > ATH_KEYMAX) { | 1175 | if (sc->sc_keymax > ATH_KEYMAX) { |
1174 | DPRINTF(sc, ATH_DBG_KEYCACHE, | 1176 | DPRINTF(sc, ATH_DBG_KEYCACHE, |
1175 | "%s: Warning, using only %u entries in %u key cache\n", | 1177 | "%s: Warning, using only %u entries in %u key cache\n", |
@@ -1284,7 +1286,7 @@ int ath_init(u16 devid, struct ath_softc *sc) | |||
1284 | goto bad2; | 1286 | goto bad2; |
1285 | } | 1287 | } |
1286 | 1288 | ||
1287 | if (ath9k_hw_getcapability(ah, HAL_CAP_CIPHER, | 1289 | if (ath9k_hw_getcapability(ah, ATH9K_CAP_CIPHER, |
1288 | ATH9K_CIPHER_TKIP, NULL)) { | 1290 | ATH9K_CIPHER_TKIP, NULL)) { |
1289 | /* | 1291 | /* |
1290 | * Whether we should enable h/w TKIP MIC. | 1292 | * Whether we should enable h/w TKIP MIC. |
@@ -1292,7 +1294,8 @@ int ath_init(u16 devid, struct ath_softc *sc) | |||
1292 | * report WMM capable, so it's always safe to turn on | 1294 | * report WMM capable, so it's always safe to turn on |
1293 | * TKIP MIC in this case. | 1295 | * TKIP MIC in this case. |
1294 | */ | 1296 | */ |
1295 | ath9k_hw_setcapability(sc->sc_ah, HAL_CAP_TKIP_MIC, 0, 1, NULL); | 1297 | ath9k_hw_setcapability(sc->sc_ah, ATH9K_CAP_TKIP_MIC, |
1298 | 0, 1, NULL); | ||
1296 | } | 1299 | } |
1297 | 1300 | ||
1298 | /* | 1301 | /* |
@@ -1301,30 +1304,30 @@ int ath_init(u16 devid, struct ath_softc *sc) | |||
1301 | * With split mic keys the number of stations is limited | 1304 | * With split mic keys the number of stations is limited |
1302 | * to 27 otherwise 59. | 1305 | * to 27 otherwise 59. |
1303 | */ | 1306 | */ |
1304 | if (ath9k_hw_getcapability(ah, HAL_CAP_CIPHER, | 1307 | if (ath9k_hw_getcapability(ah, ATH9K_CAP_CIPHER, |
1305 | ATH9K_CIPHER_TKIP, NULL) | 1308 | ATH9K_CIPHER_TKIP, NULL) |
1306 | && ath9k_hw_getcapability(ah, HAL_CAP_CIPHER, | 1309 | && ath9k_hw_getcapability(ah, ATH9K_CAP_CIPHER, |
1307 | ATH9K_CIPHER_MIC, NULL) | 1310 | ATH9K_CIPHER_MIC, NULL) |
1308 | && ath9k_hw_getcapability(ah, HAL_CAP_TKIP_SPLIT, | 1311 | && ath9k_hw_getcapability(ah, ATH9K_CAP_TKIP_SPLIT, |
1309 | 0, NULL)) | 1312 | 0, NULL)) |
1310 | sc->sc_splitmic = 1; | 1313 | sc->sc_splitmic = 1; |
1311 | 1314 | ||
1312 | /* turn on mcast key search if possible */ | 1315 | /* turn on mcast key search if possible */ |
1313 | if (!ath9k_hw_getcapability(ah, HAL_CAP_MCAST_KEYSRCH, 0, NULL)) | 1316 | if (!ath9k_hw_getcapability(ah, ATH9K_CAP_MCAST_KEYSRCH, 0, NULL)) |
1314 | (void)ath9k_hw_setcapability(ah, HAL_CAP_MCAST_KEYSRCH, 1, | 1317 | (void)ath9k_hw_setcapability(ah, ATH9K_CAP_MCAST_KEYSRCH, 1, |
1315 | 1, NULL); | 1318 | 1, NULL); |
1316 | 1319 | ||
1317 | sc->sc_config.txpowlimit = ATH_TXPOWER_MAX; | 1320 | sc->sc_config.txpowlimit = ATH_TXPOWER_MAX; |
1318 | sc->sc_config.txpowlimit_override = 0; | 1321 | sc->sc_config.txpowlimit_override = 0; |
1319 | 1322 | ||
1320 | /* 11n Capabilities */ | 1323 | /* 11n Capabilities */ |
1321 | if (ah->ah_caps.halHTSupport) { | 1324 | if (ah->ah_caps.hw_caps & ATH9K_HW_CAP_HT) { |
1322 | sc->sc_txaggr = 1; | 1325 | sc->sc_txaggr = 1; |
1323 | sc->sc_rxaggr = 1; | 1326 | sc->sc_rxaggr = 1; |
1324 | } | 1327 | } |
1325 | 1328 | ||
1326 | sc->sc_tx_chainmask = ah->ah_caps.halTxChainMask; | 1329 | sc->sc_tx_chainmask = ah->ah_caps.tx_chainmask; |
1327 | sc->sc_rx_chainmask = ah->ah_caps.halRxChainMask; | 1330 | sc->sc_rx_chainmask = ah->ah_caps.rx_chainmask; |
1328 | 1331 | ||
1329 | /* Configuration for rx chain detection */ | 1332 | /* Configuration for rx chain detection */ |
1330 | sc->sc_rxchaindetect_ref = 0; | 1333 | sc->sc_rxchaindetect_ref = 0; |
@@ -1333,11 +1336,11 @@ int ath_init(u16 devid, struct ath_softc *sc) | |||
1333 | sc->sc_rxchaindetect_delta5GHz = 30; | 1336 | sc->sc_rxchaindetect_delta5GHz = 30; |
1334 | sc->sc_rxchaindetect_delta2GHz = 30; | 1337 | sc->sc_rxchaindetect_delta2GHz = 30; |
1335 | 1338 | ||
1336 | ath9k_hw_setcapability(ah, HAL_CAP_DIVERSITY, 1, true, NULL); | 1339 | ath9k_hw_setcapability(ah, ATH9K_CAP_DIVERSITY, 1, true, NULL); |
1337 | sc->sc_defant = ath9k_hw_getdefantenna(ah); | 1340 | sc->sc_defant = ath9k_hw_getdefantenna(ah); |
1338 | 1341 | ||
1339 | ath9k_hw_getmac(ah, sc->sc_myaddr); | 1342 | ath9k_hw_getmac(ah, sc->sc_myaddr); |
1340 | if (ah->ah_caps.halBssIdMaskSupport) { | 1343 | if (ah->ah_caps.hw_caps & ATH9K_HW_CAP_BSSIDMASK) { |
1341 | ath9k_hw_getbssidmask(ah, sc->sc_bssidmask); | 1344 | ath9k_hw_getbssidmask(ah, sc->sc_bssidmask); |
1342 | ATH_SET_VAP_BSSID_MASK(sc->sc_bssidmask); | 1345 | ATH_SET_VAP_BSSID_MASK(sc->sc_bssidmask); |
1343 | ath9k_hw_setbssidmask(ah, sc->sc_bssidmask); | 1346 | ath9k_hw_setbssidmask(ah, sc->sc_bssidmask); |
@@ -1555,7 +1558,7 @@ void ath_update_txpow(struct ath_softc *sc) | |||
1555 | if (sc->sc_curtxpow != sc->sc_config.txpowlimit) { | 1558 | if (sc->sc_curtxpow != sc->sc_config.txpowlimit) { |
1556 | ath9k_hw_set_txpowerlimit(ah, sc->sc_config.txpowlimit); | 1559 | ath9k_hw_set_txpowerlimit(ah, sc->sc_config.txpowlimit); |
1557 | /* read back in case value is clamped */ | 1560 | /* read back in case value is clamped */ |
1558 | ath9k_hw_getcapability(ah, HAL_CAP_TXPOW, 1, &txpow); | 1561 | ath9k_hw_getcapability(ah, ATH9K_CAP_TXPOW, 1, &txpow); |
1559 | sc->sc_curtxpow = txpow; | 1562 | sc->sc_curtxpow = txpow; |
1560 | } | 1563 | } |
1561 | } | 1564 | } |
@@ -1757,7 +1760,7 @@ int ath_descdma_setup(struct ath_softc *sc, | |||
1757 | * descriptors that cross the 4K page boundary. Assume | 1760 | * descriptors that cross the 4K page boundary. Assume |
1758 | * one skipped descriptor per 4K page. | 1761 | * one skipped descriptor per 4K page. |
1759 | */ | 1762 | */ |
1760 | if (!(sc->sc_ah->ah_caps.hal4kbSplitTransSupport)) { | 1763 | if (!(sc->sc_ah->ah_caps.hw_caps & ATH9K_HW_CAP_4KB_SPLITTRANS)) { |
1761 | u32 ndesc_skipped = | 1764 | u32 ndesc_skipped = |
1762 | ATH_DESC_4KB_BOUND_NUM_SKIPPED(dd->dd_desc_len); | 1765 | ATH_DESC_4KB_BOUND_NUM_SKIPPED(dd->dd_desc_len); |
1763 | u32 dma_len; | 1766 | u32 dma_len; |
@@ -1798,7 +1801,8 @@ int ath_descdma_setup(struct ath_softc *sc, | |||
1798 | bf->bf_desc = ds; | 1801 | bf->bf_desc = ds; |
1799 | bf->bf_daddr = DS2PHYS(dd, ds); | 1802 | bf->bf_daddr = DS2PHYS(dd, ds); |
1800 | 1803 | ||
1801 | if (!(sc->sc_ah->ah_caps.hal4kbSplitTransSupport)) { | 1804 | if (!(sc->sc_ah->ah_caps.hw_caps & |
1805 | ATH9K_HW_CAP_4KB_SPLITTRANS)) { | ||
1802 | /* | 1806 | /* |
1803 | * Skip descriptor addresses which can cause 4KB | 1807 | * Skip descriptor addresses which can cause 4KB |
1804 | * boundary crossing (addr + length) with a 32 dword | 1808 | * boundary crossing (addr + length) with a 32 dword |
diff --git a/drivers/net/wireless/ath9k/hw.c b/drivers/net/wireless/ath9k/hw.c index 63d0ead1c412..0dd11ee3b314 100644 --- a/drivers/net/wireless/ath9k/hw.c +++ b/drivers/net/wireless/ath9k/hw.c | |||
@@ -335,40 +335,40 @@ static void ath9k_hw_set_defaults(struct ath_hal *ah) | |||
335 | { | 335 | { |
336 | int i; | 336 | int i; |
337 | 337 | ||
338 | ah->ah_config.ath_hal_dma_beacon_response_time = 2; | 338 | ah->ah_config.dma_beacon_response_time = 2; |
339 | ah->ah_config.ath_hal_sw_beacon_response_time = 10; | 339 | ah->ah_config.sw_beacon_response_time = 10; |
340 | ah->ah_config.ath_hal_additional_swba_backoff = 0; | 340 | ah->ah_config.additional_swba_backoff = 0; |
341 | ah->ah_config.ath_hal_6mb_ack = 0x0; | 341 | ah->ah_config.ack_6mb = 0x0; |
342 | ah->ah_config.ath_hal_cwmIgnoreExtCCA = 0; | 342 | ah->ah_config.cwm_ignore_extcca = 0; |
343 | ah->ah_config.ath_hal_pciePowerSaveEnable = 0; | 343 | ah->ah_config.pcie_powersave_enable = 0; |
344 | ah->ah_config.ath_hal_pcieL1SKPEnable = 0; | 344 | ah->ah_config.pcie_l1skp_enable = 0; |
345 | ah->ah_config.ath_hal_pcieClockReq = 0; | 345 | ah->ah_config.pcie_clock_req = 0; |
346 | ah->ah_config.ath_hal_pciePowerReset = 0x100; | 346 | ah->ah_config.pcie_power_reset = 0x100; |
347 | ah->ah_config.ath_hal_pcieRestore = 0; | 347 | ah->ah_config.pcie_restore = 0; |
348 | ah->ah_config.ath_hal_pcieWaen = 0; | 348 | ah->ah_config.pcie_waen = 0; |
349 | ah->ah_config.ath_hal_analogShiftReg = 1; | 349 | ah->ah_config.analog_shiftreg = 1; |
350 | ah->ah_config.ath_hal_htEnable = 1; | 350 | ah->ah_config.ht_enable = 1; |
351 | ah->ah_config.ath_hal_ofdmTrigLow = 200; | 351 | ah->ah_config.ofdm_trig_low = 200; |
352 | ah->ah_config.ath_hal_ofdmTrigHigh = 500; | 352 | ah->ah_config.ofdm_trig_high = 500; |
353 | ah->ah_config.ath_hal_cckTrigHigh = 200; | 353 | ah->ah_config.cck_trig_high = 200; |
354 | ah->ah_config.ath_hal_cckTrigLow = 100; | 354 | ah->ah_config.cck_trig_low = 100; |
355 | ah->ah_config.ath_hal_enableANI = 0; | 355 | ah->ah_config.enable_ani = 0; |
356 | ah->ah_config.ath_hal_noiseImmunityLvl = 4; | 356 | ah->ah_config.noise_immunity_level = 4; |
357 | ah->ah_config.ath_hal_ofdmWeakSigDet = 1; | 357 | ah->ah_config.ofdm_weaksignal_det = 1; |
358 | ah->ah_config.ath_hal_cckWeakSigThr = 0; | 358 | ah->ah_config.cck_weaksignal_thr = 0; |
359 | ah->ah_config.ath_hal_spurImmunityLvl = 2; | 359 | ah->ah_config.spur_immunity_level = 2; |
360 | ah->ah_config.ath_hal_firStepLvl = 0; | 360 | ah->ah_config.firstep_level = 0; |
361 | ah->ah_config.ath_hal_rssiThrHigh = 40; | 361 | ah->ah_config.rssi_thr_high = 40; |
362 | ah->ah_config.ath_hal_rssiThrLow = 7; | 362 | ah->ah_config.rssi_thr_low = 7; |
363 | ah->ah_config.ath_hal_diversityControl = 0; | 363 | ah->ah_config.diversity_control = 0; |
364 | ah->ah_config.ath_hal_antennaSwitchSwap = 0; | 364 | ah->ah_config.antenna_switch_swap = 0; |
365 | 365 | ||
366 | for (i = 0; i < AR_EEPROM_MODAL_SPURS; i++) { | 366 | for (i = 0; i < AR_EEPROM_MODAL_SPURS; i++) { |
367 | ah->ah_config.ath_hal_spurChans[i][0] = AR_NO_SPUR; | 367 | ah->ah_config.spurchans[i][0] = AR_NO_SPUR; |
368 | ah->ah_config.ath_hal_spurChans[i][1] = AR_NO_SPUR; | 368 | ah->ah_config.spurchans[i][1] = AR_NO_SPUR; |
369 | } | 369 | } |
370 | 370 | ||
371 | ah->ah_config.ath_hal_intrMitigation = 0; | 371 | ah->ah_config.intr_mitigation = 0; |
372 | } | 372 | } |
373 | 373 | ||
374 | static inline void ath9k_hw_override_ini(struct ath_hal *ah, | 374 | static inline void ath9k_hw_override_ini(struct ath_hal *ah, |
@@ -458,7 +458,7 @@ static void ath9k_hw_analog_shift_rmw(struct ath_hal *ah, | |||
458 | 458 | ||
459 | REG_WRITE(ah, reg, regVal); | 459 | REG_WRITE(ah, reg, regVal); |
460 | 460 | ||
461 | if (ah->ah_config.ath_hal_analogShiftReg) | 461 | if (ah->ah_config.analog_shiftreg) |
462 | udelay(100); | 462 | udelay(100); |
463 | 463 | ||
464 | return; | 464 | return; |
@@ -1001,7 +1001,7 @@ void ath9k_hw_setrxfilter(struct ath_hal *ah, u32 bits) | |||
1001 | } | 1001 | } |
1002 | 1002 | ||
1003 | bool ath9k_hw_setcapability(struct ath_hal *ah, | 1003 | bool ath9k_hw_setcapability(struct ath_hal *ah, |
1004 | enum hal_capability_type type, | 1004 | enum ath9k_capability_type type, |
1005 | u32 capability, | 1005 | u32 capability, |
1006 | u32 setting, | 1006 | u32 setting, |
1007 | int *status) | 1007 | int *status) |
@@ -1010,7 +1010,7 @@ bool ath9k_hw_setcapability(struct ath_hal *ah, | |||
1010 | u32 v; | 1010 | u32 v; |
1011 | 1011 | ||
1012 | switch (type) { | 1012 | switch (type) { |
1013 | case HAL_CAP_TKIP_MIC: | 1013 | case ATH9K_CAP_TKIP_MIC: |
1014 | if (setting) | 1014 | if (setting) |
1015 | ahp->ah_staId1Defaults |= | 1015 | ahp->ah_staId1Defaults |= |
1016 | AR_STA_ID1_CRPT_MIC_ENABLE; | 1016 | AR_STA_ID1_CRPT_MIC_ENABLE; |
@@ -1018,7 +1018,7 @@ bool ath9k_hw_setcapability(struct ath_hal *ah, | |||
1018 | ahp->ah_staId1Defaults &= | 1018 | ahp->ah_staId1Defaults &= |
1019 | ~AR_STA_ID1_CRPT_MIC_ENABLE; | 1019 | ~AR_STA_ID1_CRPT_MIC_ENABLE; |
1020 | return true; | 1020 | return true; |
1021 | case HAL_CAP_DIVERSITY: | 1021 | case ATH9K_CAP_DIVERSITY: |
1022 | v = REG_READ(ah, AR_PHY_CCK_DETECT); | 1022 | v = REG_READ(ah, AR_PHY_CCK_DETECT); |
1023 | if (setting) | 1023 | if (setting) |
1024 | v |= AR_PHY_CCK_DETECT_BB_ENABLE_ANT_FAST_DIV; | 1024 | v |= AR_PHY_CCK_DETECT_BB_ENABLE_ANT_FAST_DIV; |
@@ -1026,13 +1026,13 @@ bool ath9k_hw_setcapability(struct ath_hal *ah, | |||
1026 | v &= ~AR_PHY_CCK_DETECT_BB_ENABLE_ANT_FAST_DIV; | 1026 | v &= ~AR_PHY_CCK_DETECT_BB_ENABLE_ANT_FAST_DIV; |
1027 | REG_WRITE(ah, AR_PHY_CCK_DETECT, v); | 1027 | REG_WRITE(ah, AR_PHY_CCK_DETECT, v); |
1028 | return true; | 1028 | return true; |
1029 | case HAL_CAP_MCAST_KEYSRCH: | 1029 | case ATH9K_CAP_MCAST_KEYSRCH: |
1030 | if (setting) | 1030 | if (setting) |
1031 | ahp->ah_staId1Defaults |= AR_STA_ID1_MCAST_KSRCH; | 1031 | ahp->ah_staId1Defaults |= AR_STA_ID1_MCAST_KSRCH; |
1032 | else | 1032 | else |
1033 | ahp->ah_staId1Defaults &= ~AR_STA_ID1_MCAST_KSRCH; | 1033 | ahp->ah_staId1Defaults &= ~AR_STA_ID1_MCAST_KSRCH; |
1034 | return true; | 1034 | return true; |
1035 | case HAL_CAP_TSF_ADJUST: | 1035 | case ATH9K_CAP_TSF_ADJUST: |
1036 | if (setting) | 1036 | if (setting) |
1037 | ahp->ah_miscMode |= AR_PCU_TX_ADD_TSF; | 1037 | ahp->ah_miscMode |= AR_PCU_TX_ADD_TSF; |
1038 | else | 1038 | else |
@@ -1161,7 +1161,7 @@ void ath9k_hw_set11nmac2040(struct ath_hal *ah, enum ath9k_ht_macmode mode) | |||
1161 | u32 macmode; | 1161 | u32 macmode; |
1162 | 1162 | ||
1163 | if (mode == ATH9K_HT_MACMODE_2040 && | 1163 | if (mode == ATH9K_HT_MACMODE_2040 && |
1164 | !ah->ah_config.ath_hal_cwmIgnoreExtCCA) | 1164 | !ah->ah_config.cwm_ignore_extcca) |
1165 | macmode = AR_2040_JOINED_RX_CLEAR; | 1165 | macmode = AR_2040_JOINED_RX_CLEAR; |
1166 | else | 1166 | else |
1167 | macmode = 0; | 1167 | macmode = 0; |
@@ -1214,9 +1214,9 @@ static struct ath_hal_5416 *ath9k_hw_newstate(u16 devid, | |||
1214 | ah->ah_tpScale = ATH9K_TP_SCALE_MAX; | 1214 | ah->ah_tpScale = ATH9K_TP_SCALE_MAX; |
1215 | 1215 | ||
1216 | ahp->ah_atimWindow = 0; | 1216 | ahp->ah_atimWindow = 0; |
1217 | ahp->ah_diversityControl = ah->ah_config.ath_hal_diversityControl; | 1217 | ahp->ah_diversityControl = ah->ah_config.diversity_control; |
1218 | ahp->ah_antennaSwitchSwap = | 1218 | ahp->ah_antennaSwitchSwap = |
1219 | ah->ah_config.ath_hal_antennaSwitchSwap; | 1219 | ah->ah_config.antenna_switch_swap; |
1220 | 1220 | ||
1221 | ahp->ah_staId1Defaults = AR_STA_ID1_CRPT_MIC_ENABLE; | 1221 | ahp->ah_staId1Defaults = AR_STA_ID1_CRPT_MIC_ENABLE; |
1222 | ahp->ah_beaconInterval = 100; | 1222 | ahp->ah_beaconInterval = 100; |
@@ -1371,13 +1371,13 @@ static u16 ath9k_hw_eeprom_get_spur_chan(struct ath_hal *ah, | |||
1371 | 1371 | ||
1372 | DPRINTF(ah->ah_sc, ATH_DBG_ANI, | 1372 | DPRINTF(ah->ah_sc, ATH_DBG_ANI, |
1373 | "Getting spur idx %d is2Ghz. %d val %x\n", | 1373 | "Getting spur idx %d is2Ghz. %d val %x\n", |
1374 | i, is2GHz, ah->ah_config.ath_hal_spurChans[i][is2GHz]); | 1374 | i, is2GHz, ah->ah_config.spurchans[i][is2GHz]); |
1375 | 1375 | ||
1376 | switch (ah->ah_config.ath_hal_spurMode) { | 1376 | switch (ah->ah_config.spurmode) { |
1377 | case SPUR_DISABLE: | 1377 | case SPUR_DISABLE: |
1378 | break; | 1378 | break; |
1379 | case SPUR_ENABLE_IOCTL: | 1379 | case SPUR_ENABLE_IOCTL: |
1380 | spur_val = ah->ah_config.ath_hal_spurChans[i][is2GHz]; | 1380 | spur_val = ah->ah_config.spurchans[i][is2GHz]; |
1381 | DPRINTF(ah->ah_sc, ATH_DBG_ANI, | 1381 | DPRINTF(ah->ah_sc, ATH_DBG_ANI, |
1382 | "Getting spur val from new loc. %d\n", spur_val); | 1382 | "Getting spur val from new loc. %d\n", spur_val); |
1383 | break; | 1383 | break; |
@@ -2094,7 +2094,7 @@ static void ath9k_hw_ani_attach(struct ath_hal *ah) | |||
2094 | ath9k_enable_mib_counters(ah); | 2094 | ath9k_enable_mib_counters(ah); |
2095 | } | 2095 | } |
2096 | ahp->ah_aniPeriod = ATH9K_ANI_PERIOD; | 2096 | ahp->ah_aniPeriod = ATH9K_ANI_PERIOD; |
2097 | if (ah->ah_config.ath_hal_enableANI) | 2097 | if (ah->ah_config.enable_ani) |
2098 | ahp->ah_procPhyErr |= HAL_PROCESS_ANI; | 2098 | ahp->ah_procPhyErr |= HAL_PROCESS_ANI; |
2099 | } | 2099 | } |
2100 | 2100 | ||
@@ -2504,13 +2504,13 @@ static void ath9k_ani_reset(struct ath_hal *ah) | |||
2504 | ATH9K_RX_FILTER_PHYERR); | 2504 | ATH9K_RX_FILTER_PHYERR); |
2505 | if (ah->ah_opmode == ATH9K_M_HOSTAP) { | 2505 | if (ah->ah_opmode == ATH9K_M_HOSTAP) { |
2506 | ahp->ah_curani->ofdmTrigHigh = | 2506 | ahp->ah_curani->ofdmTrigHigh = |
2507 | ah->ah_config.ath_hal_ofdmTrigHigh; | 2507 | ah->ah_config.ofdm_trig_high; |
2508 | ahp->ah_curani->ofdmTrigLow = | 2508 | ahp->ah_curani->ofdmTrigLow = |
2509 | ah->ah_config.ath_hal_ofdmTrigLow; | 2509 | ah->ah_config.ofdm_trig_low; |
2510 | ahp->ah_curani->cckTrigHigh = | 2510 | ahp->ah_curani->cckTrigHigh = |
2511 | ah->ah_config.ath_hal_cckTrigHigh; | 2511 | ah->ah_config.cck_trig_high; |
2512 | ahp->ah_curani->cckTrigLow = | 2512 | ahp->ah_curani->cckTrigLow = |
2513 | ah->ah_config.ath_hal_cckTrigLow; | 2513 | ah->ah_config.cck_trig_low; |
2514 | } | 2514 | } |
2515 | ath9k_ani_restart(ah); | 2515 | ath9k_ani_restart(ah); |
2516 | return; | 2516 | return; |
@@ -2870,7 +2870,7 @@ static bool ath9k_hw_set_gpio(struct ath_hal *ah, u32 gpio, | |||
2870 | 2870 | ||
2871 | static u32 ath9k_hw_gpio_get(struct ath_hal *ah, u32 gpio) | 2871 | static u32 ath9k_hw_gpio_get(struct ath_hal *ah, u32 gpio) |
2872 | { | 2872 | { |
2873 | if (gpio >= ah->ah_caps.halNumGpioPins) | 2873 | if (gpio >= ah->ah_caps.num_gpio_pins) |
2874 | return 0xffffffff; | 2874 | return 0xffffffff; |
2875 | 2875 | ||
2876 | if (AR_SREV_9280_10_OR_LATER(ah)) { | 2876 | if (AR_SREV_9280_10_OR_LATER(ah)) { |
@@ -2947,7 +2947,7 @@ static u32 ath9k_hw_ini_fixup(struct ath_hal *ah, | |||
2947 | static bool ath9k_hw_fill_cap_info(struct ath_hal *ah) | 2947 | static bool ath9k_hw_fill_cap_info(struct ath_hal *ah) |
2948 | { | 2948 | { |
2949 | struct ath_hal_5416 *ahp = AH5416(ah); | 2949 | struct ath_hal_5416 *ahp = AH5416(ah); |
2950 | struct hal_capabilities *pCap = &ah->ah_caps; | 2950 | struct ath9k_hw_capabilities *pCap = &ah->ah_caps; |
2951 | u16 capField = 0, eeval; | 2951 | u16 capField = 0, eeval; |
2952 | 2952 | ||
2953 | eeval = ath9k_hw_get_eeprom(ahp, EEP_REG_0); | 2953 | eeval = ath9k_hw_get_eeprom(ahp, EEP_REG_0); |
@@ -2970,12 +2970,12 @@ static bool ath9k_hw_fill_cap_info(struct ath_hal *ah) | |||
2970 | ah->ah_currentRD); | 2970 | ah->ah_currentRD); |
2971 | } | 2971 | } |
2972 | 2972 | ||
2973 | pCap->halWirelessModes = 0; | 2973 | pCap->wireless_modes = 0; |
2974 | eeval = ath9k_hw_get_eeprom(ahp, EEP_OP_MODE); | 2974 | eeval = ath9k_hw_get_eeprom(ahp, EEP_OP_MODE); |
2975 | 2975 | ||
2976 | if (eeval & AR5416_OPFLAGS_11A) { | 2976 | if (eeval & AR5416_OPFLAGS_11A) { |
2977 | pCap->halWirelessModes |= ATH9K_MODE_SEL_11A | | 2977 | pCap->wireless_modes |= ATH9K_MODE_SEL_11A | |
2978 | ((!ah->ah_config.ath_hal_htEnable | 2978 | ((!ah->ah_config.ht_enable |
2979 | || (eeval & AR5416_OPFLAGS_N_5G_HT20)) ? 0 | 2979 | || (eeval & AR5416_OPFLAGS_N_5G_HT20)) ? 0 |
2980 | : (ATH9K_MODE_SEL_11NA_HT20 | | 2980 | : (ATH9K_MODE_SEL_11NA_HT20 | |
2981 | ((eeval & AR5416_OPFLAGS_N_5G_HT40) ? 0 | 2981 | ((eeval & AR5416_OPFLAGS_N_5G_HT40) ? 0 |
@@ -2983,9 +2983,9 @@ static bool ath9k_hw_fill_cap_info(struct ath_hal *ah) | |||
2983 | ATH9K_MODE_SEL_11NA_HT40MINUS)))); | 2983 | ATH9K_MODE_SEL_11NA_HT40MINUS)))); |
2984 | } | 2984 | } |
2985 | if (eeval & AR5416_OPFLAGS_11G) { | 2985 | if (eeval & AR5416_OPFLAGS_11G) { |
2986 | pCap->halWirelessModes |= | 2986 | pCap->wireless_modes |= |
2987 | ATH9K_MODE_SEL_11B | ATH9K_MODE_SEL_11G | | 2987 | ATH9K_MODE_SEL_11B | ATH9K_MODE_SEL_11G | |
2988 | ((!ah->ah_config.ath_hal_htEnable | 2988 | ((!ah->ah_config.ht_enable |
2989 | || (eeval & AR5416_OPFLAGS_N_2G_HT20)) ? 0 | 2989 | || (eeval & AR5416_OPFLAGS_N_2G_HT20)) ? 0 |
2990 | : (ATH9K_MODE_SEL_11NG_HT20 | | 2990 | : (ATH9K_MODE_SEL_11NG_HT20 | |
2991 | ((eeval & AR5416_OPFLAGS_N_2G_HT40) ? 0 | 2991 | ((eeval & AR5416_OPFLAGS_N_2G_HT40) ? 0 |
@@ -2993,79 +2993,82 @@ static bool ath9k_hw_fill_cap_info(struct ath_hal *ah) | |||
2993 | ATH9K_MODE_SEL_11NG_HT40MINUS)))); | 2993 | ATH9K_MODE_SEL_11NG_HT40MINUS)))); |
2994 | 2994 | ||
2995 | } | 2995 | } |
2996 | pCap->halTxChainMask = ath9k_hw_get_eeprom(ahp, EEP_TX_MASK); | 2996 | pCap->tx_chainmask = ath9k_hw_get_eeprom(ahp, EEP_TX_MASK); |
2997 | if ((ah->ah_isPciExpress) | 2997 | if ((ah->ah_isPciExpress) |
2998 | || (eeval & AR5416_OPFLAGS_11A)) { | 2998 | || (eeval & AR5416_OPFLAGS_11A)) { |
2999 | pCap->halRxChainMask = | 2999 | pCap->rx_chainmask = |
3000 | ath9k_hw_get_eeprom(ahp, EEP_RX_MASK); | 3000 | ath9k_hw_get_eeprom(ahp, EEP_RX_MASK); |
3001 | } else { | 3001 | } else { |
3002 | pCap->halRxChainMask = | 3002 | pCap->rx_chainmask = |
3003 | (ath9k_hw_gpio_get(ah, 0)) ? 0x5 : 0x7; | 3003 | (ath9k_hw_gpio_get(ah, 0)) ? 0x5 : 0x7; |
3004 | } | 3004 | } |
3005 | 3005 | ||
3006 | if (!(AR_SREV_9280(ah) && (ah->ah_macRev == 0))) | 3006 | if (!(AR_SREV_9280(ah) && (ah->ah_macRev == 0))) |
3007 | ahp->ah_miscMode |= AR_PCU_MIC_NEW_LOC_ENA; | 3007 | ahp->ah_miscMode |= AR_PCU_MIC_NEW_LOC_ENA; |
3008 | 3008 | ||
3009 | pCap->halLow2GhzChan = 2312; | 3009 | pCap->low_2ghz_chan = 2312; |
3010 | pCap->halHigh2GhzChan = 2732; | 3010 | pCap->high_2ghz_chan = 2732; |
3011 | 3011 | ||
3012 | pCap->halLow5GhzChan = 4920; | 3012 | pCap->low_5ghz_chan = 4920; |
3013 | pCap->halHigh5GhzChan = 6100; | 3013 | pCap->high_5ghz_chan = 6100; |
3014 | 3014 | ||
3015 | pCap->halCipherCkipSupport = false; | 3015 | pCap->hw_caps &= ~ATH9K_HW_CAP_CIPHER_CKIP; |
3016 | pCap->halCipherTkipSupport = true; | 3016 | pCap->hw_caps |= ATH9K_HW_CAP_CIPHER_TKIP; |
3017 | pCap->halCipherAesCcmSupport = true; | 3017 | pCap->hw_caps |= ATH9K_HW_CAP_CIPHER_AESCCM; |
3018 | 3018 | ||
3019 | pCap->halMicCkipSupport = false; | 3019 | pCap->hw_caps &= ~ATH9K_HW_CAP_MIC_CKIP; |
3020 | pCap->halMicTkipSupport = true; | 3020 | pCap->hw_caps |= ATH9K_HW_CAP_MIC_TKIP; |
3021 | pCap->halMicAesCcmSupport = true; | 3021 | pCap->hw_caps |= ATH9K_HW_CAP_MIC_AESCCM; |
3022 | 3022 | ||
3023 | pCap->halChanSpreadSupport = true; | 3023 | pCap->hw_caps |= ATH9K_HW_CAP_CHAN_SPREAD; |
3024 | 3024 | ||
3025 | pCap->halHTSupport = | 3025 | if (ah->ah_config.ht_enable) |
3026 | ah->ah_config.ath_hal_htEnable ? true : false; | 3026 | pCap->hw_caps |= ATH9K_HW_CAP_HT; |
3027 | pCap->halGTTSupport = true; | 3027 | else |
3028 | pCap->halVEOLSupport = true; | 3028 | pCap->hw_caps &= ~ATH9K_HW_CAP_HT; |
3029 | pCap->halBssIdMaskSupport = true; | 3029 | |
3030 | pCap->halMcastKeySrchSupport = false; | 3030 | pCap->hw_caps |= ATH9K_HW_CAP_GTT; |
3031 | pCap->hw_caps |= ATH9K_HW_CAP_VEOL; | ||
3032 | pCap->hw_caps |= ATH9K_HW_CAP_BSSIDMASK; | ||
3033 | pCap->hw_caps &= ~ATH9K_HW_CAP_MCAST_KEYSEARCH; | ||
3031 | 3034 | ||
3032 | if (capField & AR_EEPROM_EEPCAP_MAXQCU) | 3035 | if (capField & AR_EEPROM_EEPCAP_MAXQCU) |
3033 | pCap->halTotalQueues = | 3036 | pCap->total_queues = |
3034 | MS(capField, AR_EEPROM_EEPCAP_MAXQCU); | 3037 | MS(capField, AR_EEPROM_EEPCAP_MAXQCU); |
3035 | else | 3038 | else |
3036 | pCap->halTotalQueues = ATH9K_NUM_TX_QUEUES; | 3039 | pCap->total_queues = ATH9K_NUM_TX_QUEUES; |
3037 | 3040 | ||
3038 | if (capField & AR_EEPROM_EEPCAP_KC_ENTRIES) | 3041 | if (capField & AR_EEPROM_EEPCAP_KC_ENTRIES) |
3039 | pCap->halKeyCacheSize = | 3042 | pCap->keycache_size = |
3040 | 1 << MS(capField, AR_EEPROM_EEPCAP_KC_ENTRIES); | 3043 | 1 << MS(capField, AR_EEPROM_EEPCAP_KC_ENTRIES); |
3041 | else | 3044 | else |
3042 | pCap->halKeyCacheSize = AR_KEYTABLE_SIZE; | 3045 | pCap->keycache_size = AR_KEYTABLE_SIZE; |
3043 | 3046 | ||
3044 | pCap->halFastCCSupport = true; | 3047 | pCap->hw_caps |= ATH9K_HW_CAP_FASTCC; |
3045 | pCap->halNumMRRetries = 4; | 3048 | pCap->num_mr_retries = 4; |
3046 | pCap->halTxTrigLevelMax = MAX_TX_FIFO_THRESHOLD; | 3049 | pCap->tx_triglevel_max = MAX_TX_FIFO_THRESHOLD; |
3047 | 3050 | ||
3048 | if (AR_SREV_9280_10_OR_LATER(ah)) | 3051 | if (AR_SREV_9280_10_OR_LATER(ah)) |
3049 | pCap->halNumGpioPins = AR928X_NUM_GPIO; | 3052 | pCap->num_gpio_pins = AR928X_NUM_GPIO; |
3050 | else | 3053 | else |
3051 | pCap->halNumGpioPins = AR_NUM_GPIO; | 3054 | pCap->num_gpio_pins = AR_NUM_GPIO; |
3052 | 3055 | ||
3053 | if (AR_SREV_9280_10_OR_LATER(ah)) { | 3056 | if (AR_SREV_9280_10_OR_LATER(ah)) { |
3054 | pCap->halWowSupport = true; | 3057 | pCap->hw_caps |= ATH9K_HW_CAP_WOW; |
3055 | pCap->halWowMatchPatternExact = true; | 3058 | pCap->hw_caps |= ATH9K_HW_CAP_WOW_MATCHPATTERN_EXACT; |
3056 | } else { | 3059 | } else { |
3057 | pCap->halWowSupport = false; | 3060 | pCap->hw_caps &= ~ATH9K_HW_CAP_WOW; |
3058 | pCap->halWowMatchPatternExact = false; | 3061 | pCap->hw_caps &= ~ATH9K_HW_CAP_WOW_MATCHPATTERN_EXACT; |
3059 | } | 3062 | } |
3060 | 3063 | ||
3061 | if (AR_SREV_9160_10_OR_LATER(ah) || AR_SREV_9100(ah)) { | 3064 | if (AR_SREV_9160_10_OR_LATER(ah) || AR_SREV_9100(ah)) { |
3062 | pCap->halCSTSupport = true; | 3065 | pCap->hw_caps |= ATH9K_HW_CAP_CST; |
3063 | pCap->halRtsAggrLimit = ATH_AMPDU_LIMIT_MAX; | 3066 | pCap->rts_aggr_limit = ATH_AMPDU_LIMIT_MAX; |
3064 | } else { | 3067 | } else { |
3065 | pCap->halRtsAggrLimit = (8 * 1024); | 3068 | pCap->rts_aggr_limit = (8 * 1024); |
3066 | } | 3069 | } |
3067 | 3070 | ||
3068 | pCap->halEnhancedPmSupport = true; | 3071 | pCap->hw_caps |= ATH9K_HW_CAP_ENHANCEDPM; |
3069 | 3072 | ||
3070 | ah->ah_rfsilent = ath9k_hw_get_eeprom(ahp, EEP_RF_SILENT); | 3073 | ah->ah_rfsilent = ath9k_hw_get_eeprom(ahp, EEP_RF_SILENT); |
3071 | if (ah->ah_rfsilent & EEP_RFSILENT_ENABLED) { | 3074 | if (ah->ah_rfsilent & EEP_RFSILENT_ENABLED) { |
@@ -3074,9 +3077,9 @@ static bool ath9k_hw_fill_cap_info(struct ath_hal *ah) | |||
3074 | ahp->ah_polarity = | 3077 | ahp->ah_polarity = |
3075 | MS(ah->ah_rfsilent, EEP_RFSILENT_POLARITY); | 3078 | MS(ah->ah_rfsilent, EEP_RFSILENT_POLARITY); |
3076 | 3079 | ||
3077 | ath9k_hw_setcapability(ah, HAL_CAP_RFSILENT, 1, true, | 3080 | ath9k_hw_setcapability(ah, ATH9K_CAP_RFSILENT, 1, true, |
3078 | NULL); | 3081 | NULL); |
3079 | pCap->halRfSilentSupport = true; | 3082 | pCap->hw_caps |= ATH9K_HW_CAP_RFSILENT; |
3080 | } | 3083 | } |
3081 | 3084 | ||
3082 | if ((ah->ah_macVersion == AR_SREV_VERSION_5416_PCI) || | 3085 | if ((ah->ah_macVersion == AR_SREV_VERSION_5416_PCI) || |
@@ -3084,32 +3087,32 @@ static bool ath9k_hw_fill_cap_info(struct ath_hal *ah) | |||
3084 | (ah->ah_macVersion == AR_SREV_VERSION_9160) || | 3087 | (ah->ah_macVersion == AR_SREV_VERSION_9160) || |
3085 | (ah->ah_macVersion == AR_SREV_VERSION_9100) || | 3088 | (ah->ah_macVersion == AR_SREV_VERSION_9100) || |
3086 | (ah->ah_macVersion == AR_SREV_VERSION_9280)) | 3089 | (ah->ah_macVersion == AR_SREV_VERSION_9280)) |
3087 | pCap->halAutoSleepSupport = false; | 3090 | pCap->hw_caps &= ~ATH9K_HW_CAP_AUTOSLEEP; |
3088 | else | 3091 | else |
3089 | pCap->halAutoSleepSupport = true; | 3092 | pCap->hw_caps |= ATH9K_HW_CAP_AUTOSLEEP; |
3090 | 3093 | ||
3091 | if (AR_SREV_9280(ah)) | 3094 | if (AR_SREV_9280(ah)) |
3092 | pCap->hal4kbSplitTransSupport = false; | 3095 | pCap->hw_caps &= ~ATH9K_HW_CAP_4KB_SPLITTRANS; |
3093 | else | 3096 | else |
3094 | pCap->hal4kbSplitTransSupport = true; | 3097 | pCap->hw_caps |= ATH9K_HW_CAP_4KB_SPLITTRANS; |
3095 | 3098 | ||
3096 | if (ah->ah_currentRDExt & (1 << REG_EXT_JAPAN_MIDBAND)) { | 3099 | if (ah->ah_currentRDExt & (1 << REG_EXT_JAPAN_MIDBAND)) { |
3097 | pCap->halRegCap = | 3100 | pCap->reg_cap = |
3098 | AR_EEPROM_EEREGCAP_EN_KK_NEW_11A | | 3101 | AR_EEPROM_EEREGCAP_EN_KK_NEW_11A | |
3099 | AR_EEPROM_EEREGCAP_EN_KK_U1_EVEN | | 3102 | AR_EEPROM_EEREGCAP_EN_KK_U1_EVEN | |
3100 | AR_EEPROM_EEREGCAP_EN_KK_U2 | | 3103 | AR_EEPROM_EEREGCAP_EN_KK_U2 | |
3101 | AR_EEPROM_EEREGCAP_EN_KK_MIDBAND; | 3104 | AR_EEPROM_EEREGCAP_EN_KK_MIDBAND; |
3102 | } else { | 3105 | } else { |
3103 | pCap->halRegCap = | 3106 | pCap->reg_cap = |
3104 | AR_EEPROM_EEREGCAP_EN_KK_NEW_11A | | 3107 | AR_EEPROM_EEREGCAP_EN_KK_NEW_11A | |
3105 | AR_EEPROM_EEREGCAP_EN_KK_U1_EVEN; | 3108 | AR_EEPROM_EEREGCAP_EN_KK_U1_EVEN; |
3106 | } | 3109 | } |
3107 | 3110 | ||
3108 | pCap->halRegCap |= AR_EEPROM_EEREGCAP_EN_FCC_MIDBAND; | 3111 | pCap->reg_cap |= AR_EEPROM_EEREGCAP_EN_FCC_MIDBAND; |
3109 | 3112 | ||
3110 | pCap->halNumAntCfg5GHz = | 3113 | pCap->num_antcfg_5ghz = |
3111 | ath9k_hw_get_num_ant_config(ahp, HAL_FREQ_BAND_5GHZ); | 3114 | ath9k_hw_get_num_ant_config(ahp, HAL_FREQ_BAND_5GHZ); |
3112 | pCap->halNumAntCfg2GHz = | 3115 | pCap->num_antcfg_2ghz = |
3113 | ath9k_hw_get_num_ant_config(ahp, HAL_FREQ_BAND_2GHZ); | 3116 | ath9k_hw_get_num_ant_config(ahp, HAL_FREQ_BAND_2GHZ); |
3114 | 3117 | ||
3115 | return true; | 3118 | return true; |
@@ -3151,9 +3154,9 @@ static void ath9k_set_power_network_sleep(struct ath_hal *ah, int setChip) | |||
3151 | { | 3154 | { |
3152 | REG_SET_BIT(ah, AR_STA_ID1, AR_STA_ID1_PWR_SAV); | 3155 | REG_SET_BIT(ah, AR_STA_ID1, AR_STA_ID1_PWR_SAV); |
3153 | if (setChip) { | 3156 | if (setChip) { |
3154 | struct hal_capabilities *pCap = &ah->ah_caps; | 3157 | struct ath9k_hw_capabilities *pCap = &ah->ah_caps; |
3155 | 3158 | ||
3156 | if (!pCap->halAutoSleepSupport) { | 3159 | if (!(pCap->hw_caps & ATH9K_HW_CAP_AUTOSLEEP)) { |
3157 | REG_WRITE(ah, AR_RTC_FORCE_WAKE, | 3160 | REG_WRITE(ah, AR_RTC_FORCE_WAKE, |
3158 | AR_RTC_FORCE_WAKE_ON_INT); | 3161 | AR_RTC_FORCE_WAKE_ON_INT); |
3159 | } else { | 3162 | } else { |
@@ -3262,7 +3265,7 @@ static struct ath_hal *ath9k_hw_do_attach(u16 devid, | |||
3262 | 3265 | ||
3263 | ath9k_hw_set_defaults(ah); | 3266 | ath9k_hw_set_defaults(ah); |
3264 | 3267 | ||
3265 | if (ah->ah_config.ath_hal_intrMitigation != 0) | 3268 | if (ah->ah_config.intr_mitigation != 0) |
3266 | ahp->ah_intrMitigation = true; | 3269 | ahp->ah_intrMitigation = true; |
3267 | 3270 | ||
3268 | if (!ath9k_hw_set_reset_reg(ah, ATH9K_RESET_POWER_ON)) { | 3271 | if (!ath9k_hw_set_reset_reg(ah, ATH9K_RESET_POWER_ON)) { |
@@ -3279,18 +3282,18 @@ static struct ath_hal *ath9k_hw_do_attach(u16 devid, | |||
3279 | goto bad; | 3282 | goto bad; |
3280 | } | 3283 | } |
3281 | 3284 | ||
3282 | if (ah->ah_config.ath_hal_serializeRegMode == SER_REG_MODE_AUTO) { | 3285 | if (ah->ah_config.serialize_regmode == SER_REG_MODE_AUTO) { |
3283 | if (ah->ah_macVersion == AR_SREV_VERSION_5416_PCI) { | 3286 | if (ah->ah_macVersion == AR_SREV_VERSION_5416_PCI) { |
3284 | ah->ah_config.ath_hal_serializeRegMode = | 3287 | ah->ah_config.serialize_regmode = |
3285 | SER_REG_MODE_ON; | 3288 | SER_REG_MODE_ON; |
3286 | } else { | 3289 | } else { |
3287 | ah->ah_config.ath_hal_serializeRegMode = | 3290 | ah->ah_config.serialize_regmode = |
3288 | SER_REG_MODE_OFF; | 3291 | SER_REG_MODE_OFF; |
3289 | } | 3292 | } |
3290 | } | 3293 | } |
3291 | DPRINTF(ah->ah_sc, ATH_DBG_RESET, | 3294 | DPRINTF(ah->ah_sc, ATH_DBG_RESET, |
3292 | "%s: ath_hal_serializeRegMode is %d\n", | 3295 | "%s: serialize_regmode is %d\n", |
3293 | __func__, ah->ah_config.ath_hal_serializeRegMode); | 3296 | __func__, ah->ah_config.serialize_regmode); |
3294 | 3297 | ||
3295 | if ((ah->ah_macVersion != AR_SREV_VERSION_5416_PCI) && | 3298 | if ((ah->ah_macVersion != AR_SREV_VERSION_5416_PCI) && |
3296 | (ah->ah_macVersion != AR_SREV_VERSION_5416_PCIE) && | 3299 | (ah->ah_macVersion != AR_SREV_VERSION_5416_PCIE) && |
@@ -3334,7 +3337,7 @@ static struct ath_hal *ath9k_hw_do_attach(u16 devid, | |||
3334 | } | 3337 | } |
3335 | 3338 | ||
3336 | if (AR_SREV_9160(ah)) { | 3339 | if (AR_SREV_9160(ah)) { |
3337 | ah->ah_config.ath_hal_enableANI = 1; | 3340 | ah->ah_config.enable_ani = 1; |
3338 | ahp->ah_ani_function = (ATH9K_ANI_SPUR_IMMUNITY_LEVEL | | 3341 | ahp->ah_ani_function = (ATH9K_ANI_SPUR_IMMUNITY_LEVEL | |
3339 | ATH9K_ANI_FIRSTEP_LEVEL); | 3342 | ATH9K_ANI_FIRSTEP_LEVEL); |
3340 | } else { | 3343 | } else { |
@@ -3355,7 +3358,7 @@ static struct ath_hal *ath9k_hw_do_attach(u16 devid, | |||
3355 | INIT_INI_ARRAY(&ahp->ah_iniCommon, ar9280Common_9280_2, | 3358 | INIT_INI_ARRAY(&ahp->ah_iniCommon, ar9280Common_9280_2, |
3356 | ARRAY_SIZE(ar9280Common_9280_2), 2); | 3359 | ARRAY_SIZE(ar9280Common_9280_2), 2); |
3357 | 3360 | ||
3358 | if (ah->ah_config.ath_hal_pcieClockReq) { | 3361 | if (ah->ah_config.pcie_clock_req) { |
3359 | INIT_INI_ARRAY(&ahp->ah_iniPcieSerdes, | 3362 | INIT_INI_ARRAY(&ahp->ah_iniPcieSerdes, |
3360 | ar9280PciePhy_clkreq_off_L1_9280, | 3363 | ar9280PciePhy_clkreq_off_L1_9280, |
3361 | ARRAY_SIZE | 3364 | ARRAY_SIZE |
@@ -3528,16 +3531,16 @@ bool ath9k_get_channel_edges(struct ath_hal *ah, | |||
3528 | u16 flags, u16 *low, | 3531 | u16 flags, u16 *low, |
3529 | u16 *high) | 3532 | u16 *high) |
3530 | { | 3533 | { |
3531 | struct hal_capabilities *pCap = &ah->ah_caps; | 3534 | struct ath9k_hw_capabilities *pCap = &ah->ah_caps; |
3532 | 3535 | ||
3533 | if (flags & CHANNEL_5GHZ) { | 3536 | if (flags & CHANNEL_5GHZ) { |
3534 | *low = pCap->halLow5GhzChan; | 3537 | *low = pCap->low_5ghz_chan; |
3535 | *high = pCap->halHigh5GhzChan; | 3538 | *high = pCap->high_5ghz_chan; |
3536 | return true; | 3539 | return true; |
3537 | } | 3540 | } |
3538 | if ((flags & CHANNEL_2GHZ)) { | 3541 | if ((flags & CHANNEL_2GHZ)) { |
3539 | *low = pCap->halLow2GhzChan; | 3542 | *low = pCap->low_2ghz_chan; |
3540 | *high = pCap->halHigh2GhzChan; | 3543 | *high = pCap->high_2ghz_chan; |
3541 | 3544 | ||
3542 | return true; | 3545 | return true; |
3543 | } | 3546 | } |
@@ -3908,7 +3911,7 @@ void ath9k_hw_configpcipowersave(struct ath_hal *ah, int restore) | |||
3908 | if (ah->ah_isPciExpress != true) | 3911 | if (ah->ah_isPciExpress != true) |
3909 | return; | 3912 | return; |
3910 | 3913 | ||
3911 | if (ah->ah_config.ath_hal_pciePowerSaveEnable == 2) | 3914 | if (ah->ah_config.pcie_powersave_enable == 2) |
3912 | return; | 3915 | return; |
3913 | 3916 | ||
3914 | if (restore) | 3917 | if (restore) |
@@ -3929,7 +3932,7 @@ void ath9k_hw_configpcipowersave(struct ath_hal *ah, int restore) | |||
3929 | REG_WRITE(ah, AR_PCIE_SERDES, 0x13160820); | 3932 | REG_WRITE(ah, AR_PCIE_SERDES, 0x13160820); |
3930 | REG_WRITE(ah, AR_PCIE_SERDES, 0xe5980560); | 3933 | REG_WRITE(ah, AR_PCIE_SERDES, 0xe5980560); |
3931 | 3934 | ||
3932 | if (ah->ah_config.ath_hal_pcieClockReq) | 3935 | if (ah->ah_config.pcie_clock_req) |
3933 | REG_WRITE(ah, AR_PCIE_SERDES, 0x401deffc); | 3936 | REG_WRITE(ah, AR_PCIE_SERDES, 0x401deffc); |
3934 | else | 3937 | else |
3935 | REG_WRITE(ah, AR_PCIE_SERDES, 0x401deffd); | 3938 | REG_WRITE(ah, AR_PCIE_SERDES, 0x401deffd); |
@@ -3956,8 +3959,8 @@ void ath9k_hw_configpcipowersave(struct ath_hal *ah, int restore) | |||
3956 | 3959 | ||
3957 | REG_SET_BIT(ah, AR_PCIE_PM_CTRL, AR_PCIE_PM_CTRL_ENA); | 3960 | REG_SET_BIT(ah, AR_PCIE_PM_CTRL, AR_PCIE_PM_CTRL_ENA); |
3958 | 3961 | ||
3959 | if (ah->ah_config.ath_hal_pcieWaen) { | 3962 | if (ah->ah_config.pcie_waen) { |
3960 | REG_WRITE(ah, AR_WA, ah->ah_config.ath_hal_pcieWaen); | 3963 | REG_WRITE(ah, AR_WA, ah->ah_config.pcie_waen); |
3961 | } else { | 3964 | } else { |
3962 | if (AR_SREV_9280(ah)) | 3965 | if (AR_SREV_9280(ah)) |
3963 | REG_WRITE(ah, AR_WA, 0x0040073f); | 3966 | REG_WRITE(ah, AR_WA, 0x0040073f); |
@@ -4690,7 +4693,7 @@ static void ath9k_hw_9280_spur_mitigate(struct ath_hal *ah, | |||
4690 | ath9k_hw_get_channel_centers(ah, chan, ¢ers); | 4693 | ath9k_hw_get_channel_centers(ah, chan, ¢ers); |
4691 | freq = centers.synth_center; | 4694 | freq = centers.synth_center; |
4692 | 4695 | ||
4693 | ah->ah_config.ath_hal_spurMode = SPUR_ENABLE_EEPROM; | 4696 | ah->ah_config.spurmode = SPUR_ENABLE_EEPROM; |
4694 | for (i = 0; i < AR_EEPROM_MODAL_SPURS; i++) { | 4697 | for (i = 0; i < AR_EEPROM_MODAL_SPURS; i++) { |
4695 | cur_bb_spur = ath9k_hw_eeprom_get_spur_chan(ah, i, is2GHz); | 4698 | cur_bb_spur = ath9k_hw_eeprom_get_spur_chan(ah, i, is2GHz); |
4696 | 4699 | ||
@@ -5404,7 +5407,7 @@ ath9k_hw_process_ini(struct ath_hal *ah, | |||
5404 | REG_WRITE(ah, reg, val); | 5407 | REG_WRITE(ah, reg, val); |
5405 | 5408 | ||
5406 | if (reg >= 0x7800 && reg < 0x78a0 | 5409 | if (reg >= 0x7800 && reg < 0x78a0 |
5407 | && ah->ah_config.ath_hal_analogShiftReg) { | 5410 | && ah->ah_config.analog_shiftreg) { |
5408 | udelay(100); | 5411 | udelay(100); |
5409 | } | 5412 | } |
5410 | 5413 | ||
@@ -5418,7 +5421,7 @@ ath9k_hw_process_ini(struct ath_hal *ah, | |||
5418 | REG_WRITE(ah, reg, val); | 5421 | REG_WRITE(ah, reg, val); |
5419 | 5422 | ||
5420 | if (reg >= 0x7800 && reg < 0x78a0 | 5423 | if (reg >= 0x7800 && reg < 0x78a0 |
5421 | && ah->ah_config.ath_hal_analogShiftReg) { | 5424 | && ah->ah_config.analog_shiftreg) { |
5422 | udelay(100); | 5425 | udelay(100); |
5423 | } | 5426 | } |
5424 | 5427 | ||
@@ -5921,7 +5924,7 @@ bool ath9k_hw_reset(struct ath_hal *ah, enum ath9k_opmode opmode, | |||
5921 | REG_SET_BIT(ah, AR_GPIO_INPUT_EN_VAL, | 5924 | REG_SET_BIT(ah, AR_GPIO_INPUT_EN_VAL, |
5922 | AR_GPIO_JTAG_DISABLE); | 5925 | AR_GPIO_JTAG_DISABLE); |
5923 | 5926 | ||
5924 | if (ah->ah_caps.halWirelessModes & ATH9K_MODE_SEL_11A) { | 5927 | if (ah->ah_caps.wireless_modes & ATH9K_MODE_SEL_11A) { |
5925 | if (IS_CHAN_5GHZ(chan)) | 5928 | if (IS_CHAN_5GHZ(chan)) |
5926 | ath9k_hw_set_gpio(ah, 9, 0); | 5929 | ath9k_hw_set_gpio(ah, 9, 0); |
5927 | else | 5930 | else |
@@ -5955,7 +5958,7 @@ bool ath9k_hw_reset(struct ath_hal *ah, enum ath9k_opmode opmode, | |||
5955 | | macStaId1 | 5958 | | macStaId1 |
5956 | | AR_STA_ID1_RTS_USE_DEF | 5959 | | AR_STA_ID1_RTS_USE_DEF |
5957 | | (ah->ah_config. | 5960 | | (ah->ah_config. |
5958 | ath_hal_6mb_ack ? AR_STA_ID1_ACKCTS_6MB : 0) | 5961 | ack_6mb ? AR_STA_ID1_ACKCTS_6MB : 0) |
5959 | | ahp->ah_staId1Defaults); | 5962 | | ahp->ah_staId1Defaults); |
5960 | ath9k_hw_set_operating_mode(ah, opmode); | 5963 | ath9k_hw_set_operating_mode(ah, opmode); |
5961 | 5964 | ||
@@ -5984,7 +5987,7 @@ bool ath9k_hw_reset(struct ath_hal *ah, enum ath9k_opmode opmode, | |||
5984 | REG_WRITE(ah, AR_DQCUMASK(i), 1 << i); | 5987 | REG_WRITE(ah, AR_DQCUMASK(i), 1 << i); |
5985 | 5988 | ||
5986 | ahp->ah_intrTxqs = 0; | 5989 | ahp->ah_intrTxqs = 0; |
5987 | for (i = 0; i < ah->ah_caps.halTotalQueues; i++) | 5990 | for (i = 0; i < ah->ah_caps.total_queues; i++) |
5988 | ath9k_hw_resettxqueue(ah, i); | 5991 | ath9k_hw_resettxqueue(ah, i); |
5989 | 5992 | ||
5990 | ath9k_hw_init_interrupt_masks(ah, opmode); | 5993 | ath9k_hw_init_interrupt_masks(ah, opmode); |
@@ -6622,7 +6625,7 @@ ath9k_hw_setantennaswitch(struct ath_hal *ah, | |||
6622 | *antenna_cfgd = true; | 6625 | *antenna_cfgd = true; |
6623 | break; | 6626 | break; |
6624 | case ATH9K_ANT_FIXED_B: | 6627 | case ATH9K_ANT_FIXED_B: |
6625 | if (ah->ah_caps.halTxChainMask > | 6628 | if (ah->ah_caps.tx_chainmask > |
6626 | ATH9K_ANTENNA1_CHAINMASK) { | 6629 | ATH9K_ANTENNA1_CHAINMASK) { |
6627 | *tx_chainmask = ATH9K_ANTENNA1_CHAINMASK; | 6630 | *tx_chainmask = ATH9K_ANTENNA1_CHAINMASK; |
6628 | } | 6631 | } |
@@ -6650,14 +6653,14 @@ void ath9k_hw_setopmode(struct ath_hal *ah) | |||
6650 | } | 6653 | } |
6651 | 6654 | ||
6652 | bool | 6655 | bool |
6653 | ath9k_hw_getcapability(struct ath_hal *ah, enum hal_capability_type type, | 6656 | ath9k_hw_getcapability(struct ath_hal *ah, enum ath9k_capability_type type, |
6654 | u32 capability, u32 *result) | 6657 | u32 capability, u32 *result) |
6655 | { | 6658 | { |
6656 | struct ath_hal_5416 *ahp = AH5416(ah); | 6659 | struct ath_hal_5416 *ahp = AH5416(ah); |
6657 | const struct hal_capabilities *pCap = &ah->ah_caps; | 6660 | const struct ath9k_hw_capabilities *pCap = &ah->ah_caps; |
6658 | 6661 | ||
6659 | switch (type) { | 6662 | switch (type) { |
6660 | case HAL_CAP_CIPHER: | 6663 | case ATH9K_CAP_CIPHER: |
6661 | switch (capability) { | 6664 | switch (capability) { |
6662 | case ATH9K_CIPHER_AES_CCM: | 6665 | case ATH9K_CIPHER_AES_CCM: |
6663 | case ATH9K_CIPHER_AES_OCB: | 6666 | case ATH9K_CIPHER_AES_OCB: |
@@ -6669,7 +6672,7 @@ ath9k_hw_getcapability(struct ath_hal *ah, enum hal_capability_type type, | |||
6669 | default: | 6672 | default: |
6670 | return false; | 6673 | return false; |
6671 | } | 6674 | } |
6672 | case HAL_CAP_TKIP_MIC: | 6675 | case ATH9K_CAP_TKIP_MIC: |
6673 | switch (capability) { | 6676 | switch (capability) { |
6674 | case 0: | 6677 | case 0: |
6675 | return true; | 6678 | return true; |
@@ -6678,20 +6681,20 @@ ath9k_hw_getcapability(struct ath_hal *ah, enum hal_capability_type type, | |||
6678 | AR_STA_ID1_CRPT_MIC_ENABLE) ? true : | 6681 | AR_STA_ID1_CRPT_MIC_ENABLE) ? true : |
6679 | false; | 6682 | false; |
6680 | } | 6683 | } |
6681 | case HAL_CAP_TKIP_SPLIT: | 6684 | case ATH9K_CAP_TKIP_SPLIT: |
6682 | return (ahp->ah_miscMode & AR_PCU_MIC_NEW_LOC_ENA) ? | 6685 | return (ahp->ah_miscMode & AR_PCU_MIC_NEW_LOC_ENA) ? |
6683 | false : true; | 6686 | false : true; |
6684 | case HAL_CAP_WME_TKIPMIC: | 6687 | case ATH9K_CAP_WME_TKIPMIC: |
6685 | return 0; | 6688 | return 0; |
6686 | case HAL_CAP_PHYCOUNTERS: | 6689 | case ATH9K_CAP_PHYCOUNTERS: |
6687 | return ahp->ah_hasHwPhyCounters ? 0 : -ENXIO; | 6690 | return ahp->ah_hasHwPhyCounters ? 0 : -ENXIO; |
6688 | case HAL_CAP_DIVERSITY: | 6691 | case ATH9K_CAP_DIVERSITY: |
6689 | return (REG_READ(ah, AR_PHY_CCK_DETECT) & | 6692 | return (REG_READ(ah, AR_PHY_CCK_DETECT) & |
6690 | AR_PHY_CCK_DETECT_BB_ENABLE_ANT_FAST_DIV) ? | 6693 | AR_PHY_CCK_DETECT_BB_ENABLE_ANT_FAST_DIV) ? |
6691 | true : false; | 6694 | true : false; |
6692 | case HAL_CAP_PHYDIAG: | 6695 | case ATH9K_CAP_PHYDIAG: |
6693 | return true; | 6696 | return true; |
6694 | case HAL_CAP_MCAST_KEYSRCH: | 6697 | case ATH9K_CAP_MCAST_KEYSRCH: |
6695 | switch (capability) { | 6698 | switch (capability) { |
6696 | case 0: | 6699 | case 0: |
6697 | return true; | 6700 | return true; |
@@ -6705,19 +6708,19 @@ ath9k_hw_getcapability(struct ath_hal *ah, enum hal_capability_type type, | |||
6705 | } | 6708 | } |
6706 | } | 6709 | } |
6707 | return false; | 6710 | return false; |
6708 | case HAL_CAP_TSF_ADJUST: | 6711 | case ATH9K_CAP_TSF_ADJUST: |
6709 | return (ahp->ah_miscMode & AR_PCU_TX_ADD_TSF) ? | 6712 | return (ahp->ah_miscMode & AR_PCU_TX_ADD_TSF) ? |
6710 | true : false; | 6713 | true : false; |
6711 | case HAL_CAP_RFSILENT: | 6714 | case ATH9K_CAP_RFSILENT: |
6712 | if (capability == 3) | 6715 | if (capability == 3) |
6713 | return false; | 6716 | return false; |
6714 | case HAL_CAP_ANT_CFG_2GHZ: | 6717 | case ATH9K_CAP_ANT_CFG_2GHZ: |
6715 | *result = pCap->halNumAntCfg2GHz; | 6718 | *result = pCap->num_antcfg_2ghz; |
6716 | return true; | 6719 | return true; |
6717 | case HAL_CAP_ANT_CFG_5GHZ: | 6720 | case ATH9K_CAP_ANT_CFG_5GHZ: |
6718 | *result = pCap->halNumAntCfg5GHz; | 6721 | *result = pCap->num_antcfg_5ghz; |
6719 | return true; | 6722 | return true; |
6720 | case HAL_CAP_TXPOW: | 6723 | case ATH9K_CAP_TXPOW: |
6721 | switch (capability) { | 6724 | switch (capability) { |
6722 | case 0: | 6725 | case 0: |
6723 | return 0; | 6726 | return 0; |
@@ -6742,13 +6745,13 @@ ath9k_hw_select_antconfig(struct ath_hal *ah, u32 cfg) | |||
6742 | { | 6745 | { |
6743 | struct ath_hal_5416 *ahp = AH5416(ah); | 6746 | struct ath_hal_5416 *ahp = AH5416(ah); |
6744 | struct ath9k_channel *chan = ah->ah_curchan; | 6747 | struct ath9k_channel *chan = ah->ah_curchan; |
6745 | const struct hal_capabilities *pCap = &ah->ah_caps; | 6748 | const struct ath9k_hw_capabilities *pCap = &ah->ah_caps; |
6746 | u16 ant_config; | 6749 | u16 ant_config; |
6747 | u32 halNumAntConfig; | 6750 | u32 halNumAntConfig; |
6748 | 6751 | ||
6749 | halNumAntConfig = | 6752 | halNumAntConfig = |
6750 | IS_CHAN_2GHZ(chan) ? pCap->halNumAntCfg2GHz : pCap-> | 6753 | IS_CHAN_2GHZ(chan) ? pCap->num_antcfg_2ghz : pCap-> |
6751 | halNumAntCfg5GHz; | 6754 | num_antcfg_5ghz; |
6752 | 6755 | ||
6753 | if (cfg < halNumAntConfig) { | 6756 | if (cfg < halNumAntConfig) { |
6754 | if (!ath9k_hw_get_eeprom_antenna_cfg(ahp, chan, | 6757 | if (!ath9k_hw_get_eeprom_antenna_cfg(ahp, chan, |
@@ -6784,7 +6787,7 @@ bool ath9k_hw_getisr(struct ath_hal *ah, enum ath9k_int *masked) | |||
6784 | { | 6787 | { |
6785 | u32 isr = 0; | 6788 | u32 isr = 0; |
6786 | u32 mask2 = 0; | 6789 | u32 mask2 = 0; |
6787 | struct hal_capabilities *pCap = &ah->ah_caps; | 6790 | struct ath9k_hw_capabilities *pCap = &ah->ah_caps; |
6788 | u32 sync_cause = 0; | 6791 | u32 sync_cause = 0; |
6789 | bool fatal_int = false; | 6792 | bool fatal_int = false; |
6790 | 6793 | ||
@@ -6868,7 +6871,7 @@ bool ath9k_hw_getisr(struct ath_hal *ah, enum ath9k_int *masked) | |||
6868 | } | 6871 | } |
6869 | 6872 | ||
6870 | if (!AR_SREV_9100(ah)) { | 6873 | if (!AR_SREV_9100(ah)) { |
6871 | if (!pCap->halAutoSleepSupport) { | 6874 | if (!(pCap->hw_caps & ATH9K_HW_CAP_AUTOSLEEP)) { |
6872 | u32 isr5 = REG_READ(ah, AR_ISR_S5_S); | 6875 | u32 isr5 = REG_READ(ah, AR_ISR_S5_S); |
6873 | if (isr5 & AR_ISR_S5_TIM_TIMER) | 6876 | if (isr5 & AR_ISR_S5_TIM_TIMER) |
6874 | *masked |= ATH9K_INT_TIM_TIMER; | 6877 | *masked |= ATH9K_INT_TIM_TIMER; |
@@ -6927,7 +6930,7 @@ enum ath9k_int ath9k_hw_set_interrupts(struct ath_hal *ah, enum ath9k_int ints) | |||
6927 | struct ath_hal_5416 *ahp = AH5416(ah); | 6930 | struct ath_hal_5416 *ahp = AH5416(ah); |
6928 | u32 omask = ahp->ah_maskReg; | 6931 | u32 omask = ahp->ah_maskReg; |
6929 | u32 mask, mask2; | 6932 | u32 mask, mask2; |
6930 | struct hal_capabilities *pCap = &ah->ah_caps; | 6933 | struct ath9k_hw_capabilities *pCap = &ah->ah_caps; |
6931 | 6934 | ||
6932 | DPRINTF(ah->ah_sc, ATH_DBG_INTERRUPT, "%s: 0x%x => 0x%x\n", __func__, | 6935 | DPRINTF(ah->ah_sc, ATH_DBG_INTERRUPT, "%s: 0x%x => 0x%x\n", __func__, |
6933 | omask, ints); | 6936 | omask, ints); |
@@ -6965,7 +6968,7 @@ enum ath9k_int ath9k_hw_set_interrupts(struct ath_hal *ah, enum ath9k_int ints) | |||
6965 | mask |= AR_IMR_RXMINTR | AR_IMR_RXINTM; | 6968 | mask |= AR_IMR_RXMINTR | AR_IMR_RXINTM; |
6966 | else | 6969 | else |
6967 | mask |= AR_IMR_RXOK | AR_IMR_RXDESC; | 6970 | mask |= AR_IMR_RXOK | AR_IMR_RXDESC; |
6968 | if (!pCap->halAutoSleepSupport) | 6971 | if (!(pCap->hw_caps & ATH9K_HW_CAP_AUTOSLEEP)) |
6969 | mask |= AR_IMR_GENTMR; | 6972 | mask |= AR_IMR_GENTMR; |
6970 | } | 6973 | } |
6971 | 6974 | ||
@@ -7002,7 +7005,7 @@ enum ath9k_int ath9k_hw_set_interrupts(struct ath_hal *ah, enum ath9k_int ints) | |||
7002 | REG_WRITE(ah, AR_IMR_S2, mask | mask2); | 7005 | REG_WRITE(ah, AR_IMR_S2, mask | mask2); |
7003 | ahp->ah_maskReg = ints; | 7006 | ahp->ah_maskReg = ints; |
7004 | 7007 | ||
7005 | if (!pCap->halAutoSleepSupport) { | 7008 | if (!(pCap->hw_caps & ATH9K_HW_CAP_AUTOSLEEP)) { |
7006 | if (ints & ATH9K_INT_TIM_TIMER) | 7009 | if (ints & ATH9K_INT_TIM_TIMER) |
7007 | REG_SET_BIT(ah, AR_IMR_S5, AR_IMR_S5_TIM_TIMER); | 7010 | REG_SET_BIT(ah, AR_IMR_S5, AR_IMR_S5_TIM_TIMER); |
7008 | else | 7011 | else |
@@ -7061,11 +7064,11 @@ ath9k_hw_beaconinit(struct ath_hal *ah, | |||
7061 | REG_WRITE(ah, AR_NEXT_DMA_BEACON_ALERT, | 7064 | REG_WRITE(ah, AR_NEXT_DMA_BEACON_ALERT, |
7062 | TU_TO_USEC(next_beacon - | 7065 | TU_TO_USEC(next_beacon - |
7063 | ah->ah_config. | 7066 | ah->ah_config. |
7064 | ath_hal_dma_beacon_response_time)); | 7067 | dma_beacon_response_time)); |
7065 | REG_WRITE(ah, AR_NEXT_SWBA, | 7068 | REG_WRITE(ah, AR_NEXT_SWBA, |
7066 | TU_TO_USEC(next_beacon - | 7069 | TU_TO_USEC(next_beacon - |
7067 | ah->ah_config. | 7070 | ah->ah_config. |
7068 | ath_hal_sw_beacon_response_time)); | 7071 | sw_beacon_response_time)); |
7069 | flags |= | 7072 | flags |= |
7070 | AR_TBTT_TIMER_EN | AR_DBA_TIMER_EN | AR_SWBA_TIMER_EN; | 7073 | AR_TBTT_TIMER_EN | AR_DBA_TIMER_EN | AR_SWBA_TIMER_EN; |
7071 | break; | 7074 | break; |
@@ -7090,7 +7093,7 @@ ath9k_hw_set_sta_beacon_timers(struct ath_hal *ah, | |||
7090 | const struct ath9k_beacon_state *bs) | 7093 | const struct ath9k_beacon_state *bs) |
7091 | { | 7094 | { |
7092 | u32 nextTbtt, beaconintval, dtimperiod, beacontimeout; | 7095 | u32 nextTbtt, beaconintval, dtimperiod, beacontimeout; |
7093 | struct hal_capabilities *pCap = &ah->ah_caps; | 7096 | struct ath9k_hw_capabilities *pCap = &ah->ah_caps; |
7094 | 7097 | ||
7095 | REG_WRITE(ah, AR_NEXT_TBTT_TIMER, TU_TO_USEC(bs->bs_nexttbtt)); | 7098 | REG_WRITE(ah, AR_NEXT_TBTT_TIMER, TU_TO_USEC(bs->bs_nexttbtt)); |
7096 | 7099 | ||
@@ -7133,7 +7136,7 @@ ath9k_hw_set_sta_beacon_timers(struct ath_hal *ah, | |||
7133 | SM((CAB_TIMEOUT_VAL << 3), AR_SLEEP1_CAB_TIMEOUT) | 7136 | SM((CAB_TIMEOUT_VAL << 3), AR_SLEEP1_CAB_TIMEOUT) |
7134 | | AR_SLEEP1_ASSUME_DTIM); | 7137 | | AR_SLEEP1_ASSUME_DTIM); |
7135 | 7138 | ||
7136 | if (pCap->halAutoSleepSupport) | 7139 | if (pCap->hw_caps & ATH9K_HW_CAP_AUTOSLEEP) |
7137 | beacontimeout = (BEACON_TIMEOUT_VAL << 3); | 7140 | beacontimeout = (BEACON_TIMEOUT_VAL << 3); |
7138 | else | 7141 | else |
7139 | beacontimeout = MIN_BEACON_TIMEOUT_VAL; | 7142 | beacontimeout = MIN_BEACON_TIMEOUT_VAL; |
@@ -7152,7 +7155,7 @@ ath9k_hw_set_sta_beacon_timers(struct ath_hal *ah, | |||
7152 | 7155 | ||
7153 | bool ath9k_hw_keyisvalid(struct ath_hal *ah, u16 entry) | 7156 | bool ath9k_hw_keyisvalid(struct ath_hal *ah, u16 entry) |
7154 | { | 7157 | { |
7155 | if (entry < ah->ah_caps.halKeyCacheSize) { | 7158 | if (entry < ah->ah_caps.keycache_size) { |
7156 | u32 val = REG_READ(ah, AR_KEYTABLE_MAC1(entry)); | 7159 | u32 val = REG_READ(ah, AR_KEYTABLE_MAC1(entry)); |
7157 | if (val & AR_KEYTABLE_VALID) | 7160 | if (val & AR_KEYTABLE_VALID) |
7158 | return true; | 7161 | return true; |
@@ -7164,7 +7167,7 @@ bool ath9k_hw_keyreset(struct ath_hal *ah, u16 entry) | |||
7164 | { | 7167 | { |
7165 | u32 keyType; | 7168 | u32 keyType; |
7166 | 7169 | ||
7167 | if (entry >= ah->ah_caps.halKeyCacheSize) { | 7170 | if (entry >= ah->ah_caps.keycache_size) { |
7168 | DPRINTF(ah->ah_sc, ATH_DBG_KEYCACHE, | 7171 | DPRINTF(ah->ah_sc, ATH_DBG_KEYCACHE, |
7169 | "%s: entry %u out of range\n", __func__, entry); | 7172 | "%s: entry %u out of range\n", __func__, entry); |
7170 | return false; | 7173 | return false; |
@@ -7202,7 +7205,7 @@ ath9k_hw_keysetmac(struct ath_hal *ah, u16 entry, | |||
7202 | { | 7205 | { |
7203 | u32 macHi, macLo; | 7206 | u32 macHi, macLo; |
7204 | 7207 | ||
7205 | if (entry >= ah->ah_caps.halKeyCacheSize) { | 7208 | if (entry >= ah->ah_caps.keycache_size) { |
7206 | DPRINTF(ah->ah_sc, ATH_DBG_KEYCACHE, | 7209 | DPRINTF(ah->ah_sc, ATH_DBG_KEYCACHE, |
7207 | "%s: entry %u out of range\n", __func__, entry); | 7210 | "%s: entry %u out of range\n", __func__, entry); |
7208 | return false; | 7211 | return false; |
@@ -7229,7 +7232,7 @@ ath9k_hw_set_keycache_entry(struct ath_hal *ah, u16 entry, | |||
7229 | const struct ath9k_keyval *k, | 7232 | const struct ath9k_keyval *k, |
7230 | const u8 *mac, int xorKey) | 7233 | const u8 *mac, int xorKey) |
7231 | { | 7234 | { |
7232 | const struct hal_capabilities *pCap = &ah->ah_caps; | 7235 | const struct ath9k_hw_capabilities *pCap = &ah->ah_caps; |
7233 | u32 key0, key1, key2, key3, key4; | 7236 | u32 key0, key1, key2, key3, key4; |
7234 | u32 keyType; | 7237 | u32 keyType; |
7235 | u32 xorMask = xorKey ? | 7238 | u32 xorMask = xorKey ? |
@@ -7237,7 +7240,7 @@ ath9k_hw_set_keycache_entry(struct ath_hal *ah, u16 entry, | |||
7237 | | ATH9K_KEY_XOR) : 0; | 7240 | | ATH9K_KEY_XOR) : 0; |
7238 | struct ath_hal_5416 *ahp = AH5416(ah); | 7241 | struct ath_hal_5416 *ahp = AH5416(ah); |
7239 | 7242 | ||
7240 | if (entry >= pCap->halKeyCacheSize) { | 7243 | if (entry >= pCap->keycache_size) { |
7241 | DPRINTF(ah->ah_sc, ATH_DBG_KEYCACHE, | 7244 | DPRINTF(ah->ah_sc, ATH_DBG_KEYCACHE, |
7242 | "%s: entry %u out of range\n", __func__, entry); | 7245 | "%s: entry %u out of range\n", __func__, entry); |
7243 | return false; | 7246 | return false; |
@@ -7247,7 +7250,7 @@ ath9k_hw_set_keycache_entry(struct ath_hal *ah, u16 entry, | |||
7247 | keyType = AR_KEYTABLE_TYPE_AES; | 7250 | keyType = AR_KEYTABLE_TYPE_AES; |
7248 | break; | 7251 | break; |
7249 | case ATH9K_CIPHER_AES_CCM: | 7252 | case ATH9K_CIPHER_AES_CCM: |
7250 | if (!pCap->halCipherAesCcmSupport) { | 7253 | if (!(pCap->hw_caps & ATH9K_HW_CAP_CIPHER_AESCCM)) { |
7251 | DPRINTF(ah->ah_sc, ATH_DBG_KEYCACHE, | 7254 | DPRINTF(ah->ah_sc, ATH_DBG_KEYCACHE, |
7252 | "%s: AES-CCM not supported by " | 7255 | "%s: AES-CCM not supported by " |
7253 | "mac rev 0x%x\n", __func__, | 7256 | "mac rev 0x%x\n", __func__, |
@@ -7259,7 +7262,7 @@ ath9k_hw_set_keycache_entry(struct ath_hal *ah, u16 entry, | |||
7259 | case ATH9K_CIPHER_TKIP: | 7262 | case ATH9K_CIPHER_TKIP: |
7260 | keyType = AR_KEYTABLE_TYPE_TKIP; | 7263 | keyType = AR_KEYTABLE_TYPE_TKIP; |
7261 | if (ATH9K_IS_MIC_ENABLED(ah) | 7264 | if (ATH9K_IS_MIC_ENABLED(ah) |
7262 | && entry + 64 >= pCap->halKeyCacheSize) { | 7265 | && entry + 64 >= pCap->keycache_size) { |
7263 | DPRINTF(ah->ah_sc, ATH_DBG_KEYCACHE, | 7266 | DPRINTF(ah->ah_sc, ATH_DBG_KEYCACHE, |
7264 | "%s: entry %u inappropriate for TKIP\n", | 7267 | "%s: entry %u inappropriate for TKIP\n", |
7265 | __func__, entry); | 7268 | __func__, entry); |
@@ -7456,9 +7459,9 @@ bool ath9k_hw_settxqueueprops(struct ath_hal *ah, int q, | |||
7456 | const struct ath9k_txq_info *qInfo) | 7459 | const struct ath9k_txq_info *qInfo) |
7457 | { | 7460 | { |
7458 | struct ath_hal_5416 *ahp = AH5416(ah); | 7461 | struct ath_hal_5416 *ahp = AH5416(ah); |
7459 | struct hal_capabilities *pCap = &ah->ah_caps; | 7462 | struct ath9k_hw_capabilities *pCap = &ah->ah_caps; |
7460 | 7463 | ||
7461 | if (q >= pCap->halTotalQueues) { | 7464 | if (q >= pCap->total_queues) { |
7462 | DPRINTF(ah->ah_sc, ATH_DBG_QUEUE, "%s: invalid queue num %u\n", | 7465 | DPRINTF(ah->ah_sc, ATH_DBG_QUEUE, "%s: invalid queue num %u\n", |
7463 | __func__, q); | 7466 | __func__, q); |
7464 | return false; | 7467 | return false; |
@@ -7499,9 +7502,9 @@ ath9k_hw_gettxqueueprops(struct ath_hal *ah, int q, | |||
7499 | struct ath9k_txq_info *qInfo) | 7502 | struct ath9k_txq_info *qInfo) |
7500 | { | 7503 | { |
7501 | struct ath_hal_5416 *ahp = AH5416(ah); | 7504 | struct ath_hal_5416 *ahp = AH5416(ah); |
7502 | struct hal_capabilities *pCap = &ah->ah_caps; | 7505 | struct ath9k_hw_capabilities *pCap = &ah->ah_caps; |
7503 | 7506 | ||
7504 | if (q >= pCap->halTotalQueues) { | 7507 | if (q >= pCap->total_queues) { |
7505 | DPRINTF(ah->ah_sc, ATH_DBG_QUEUE, "%s: invalid queue num %u\n", | 7508 | DPRINTF(ah->ah_sc, ATH_DBG_QUEUE, "%s: invalid queue num %u\n", |
7506 | __func__, q); | 7509 | __func__, q); |
7507 | return false; | 7510 | return false; |
@@ -7515,28 +7518,28 @@ ath9k_hw_setuptxqueue(struct ath_hal *ah, enum ath9k_tx_queue type, | |||
7515 | { | 7518 | { |
7516 | struct ath_hal_5416 *ahp = AH5416(ah); | 7519 | struct ath_hal_5416 *ahp = AH5416(ah); |
7517 | struct ath9k_tx_queue_info *qi; | 7520 | struct ath9k_tx_queue_info *qi; |
7518 | struct hal_capabilities *pCap = &ah->ah_caps; | 7521 | struct ath9k_hw_capabilities *pCap = &ah->ah_caps; |
7519 | int q; | 7522 | int q; |
7520 | 7523 | ||
7521 | switch (type) { | 7524 | switch (type) { |
7522 | case ATH9K_TX_QUEUE_BEACON: | 7525 | case ATH9K_TX_QUEUE_BEACON: |
7523 | q = pCap->halTotalQueues - 1; | 7526 | q = pCap->total_queues - 1; |
7524 | break; | 7527 | break; |
7525 | case ATH9K_TX_QUEUE_CAB: | 7528 | case ATH9K_TX_QUEUE_CAB: |
7526 | q = pCap->halTotalQueues - 2; | 7529 | q = pCap->total_queues - 2; |
7527 | break; | 7530 | break; |
7528 | case ATH9K_TX_QUEUE_PSPOLL: | 7531 | case ATH9K_TX_QUEUE_PSPOLL: |
7529 | q = 1; | 7532 | q = 1; |
7530 | break; | 7533 | break; |
7531 | case ATH9K_TX_QUEUE_UAPSD: | 7534 | case ATH9K_TX_QUEUE_UAPSD: |
7532 | q = pCap->halTotalQueues - 3; | 7535 | q = pCap->total_queues - 3; |
7533 | break; | 7536 | break; |
7534 | case ATH9K_TX_QUEUE_DATA: | 7537 | case ATH9K_TX_QUEUE_DATA: |
7535 | for (q = 0; q < pCap->halTotalQueues; q++) | 7538 | for (q = 0; q < pCap->total_queues; q++) |
7536 | if (ahp->ah_txq[q].tqi_type == | 7539 | if (ahp->ah_txq[q].tqi_type == |
7537 | ATH9K_TX_QUEUE_INACTIVE) | 7540 | ATH9K_TX_QUEUE_INACTIVE) |
7538 | break; | 7541 | break; |
7539 | if (q == pCap->halTotalQueues) { | 7542 | if (q == pCap->total_queues) { |
7540 | DPRINTF(ah->ah_sc, ATH_DBG_QUEUE, | 7543 | DPRINTF(ah->ah_sc, ATH_DBG_QUEUE, |
7541 | "%s: no available tx queue\n", __func__); | 7544 | "%s: no available tx queue\n", __func__); |
7542 | return -1; | 7545 | return -1; |
@@ -7602,10 +7605,10 @@ ath9k_hw_set_txq_interrupts(struct ath_hal *ah, | |||
7602 | bool ath9k_hw_releasetxqueue(struct ath_hal *ah, u32 q) | 7605 | bool ath9k_hw_releasetxqueue(struct ath_hal *ah, u32 q) |
7603 | { | 7606 | { |
7604 | struct ath_hal_5416 *ahp = AH5416(ah); | 7607 | struct ath_hal_5416 *ahp = AH5416(ah); |
7605 | struct hal_capabilities *pCap = &ah->ah_caps; | 7608 | struct ath9k_hw_capabilities *pCap = &ah->ah_caps; |
7606 | struct ath9k_tx_queue_info *qi; | 7609 | struct ath9k_tx_queue_info *qi; |
7607 | 7610 | ||
7608 | if (q >= pCap->halTotalQueues) { | 7611 | if (q >= pCap->total_queues) { |
7609 | DPRINTF(ah->ah_sc, ATH_DBG_QUEUE, "%s: invalid queue num %u\n", | 7612 | DPRINTF(ah->ah_sc, ATH_DBG_QUEUE, "%s: invalid queue num %u\n", |
7610 | __func__, q); | 7613 | __func__, q); |
7611 | return false; | 7614 | return false; |
@@ -7634,12 +7637,12 @@ bool ath9k_hw_releasetxqueue(struct ath_hal *ah, u32 q) | |||
7634 | bool ath9k_hw_resettxqueue(struct ath_hal *ah, u32 q) | 7637 | bool ath9k_hw_resettxqueue(struct ath_hal *ah, u32 q) |
7635 | { | 7638 | { |
7636 | struct ath_hal_5416 *ahp = AH5416(ah); | 7639 | struct ath_hal_5416 *ahp = AH5416(ah); |
7637 | struct hal_capabilities *pCap = &ah->ah_caps; | 7640 | struct ath9k_hw_capabilities *pCap = &ah->ah_caps; |
7638 | struct ath9k_channel *chan = ah->ah_curchan; | 7641 | struct ath9k_channel *chan = ah->ah_curchan; |
7639 | struct ath9k_tx_queue_info *qi; | 7642 | struct ath9k_tx_queue_info *qi; |
7640 | u32 cwMin, chanCwMin, value; | 7643 | u32 cwMin, chanCwMin, value; |
7641 | 7644 | ||
7642 | if (q >= pCap->halTotalQueues) { | 7645 | if (q >= pCap->total_queues) { |
7643 | DPRINTF(ah->ah_sc, ATH_DBG_QUEUE, "%s: invalid queue num %u\n", | 7646 | DPRINTF(ah->ah_sc, ATH_DBG_QUEUE, "%s: invalid queue num %u\n", |
7644 | __func__, q); | 7647 | __func__, q); |
7645 | return false; | 7648 | return false; |
@@ -7739,10 +7742,10 @@ bool ath9k_hw_resettxqueue(struct ath_hal *ah, u32 q) | |||
7739 | | AR_Q_MISC_CBR_INCR_DIS1 | 7742 | | AR_Q_MISC_CBR_INCR_DIS1 |
7740 | | AR_Q_MISC_CBR_INCR_DIS0); | 7743 | | AR_Q_MISC_CBR_INCR_DIS0); |
7741 | value = (qi->tqi_readyTime | 7744 | value = (qi->tqi_readyTime |
7742 | - (ah->ah_config.ath_hal_sw_beacon_response_time - | 7745 | - (ah->ah_config.sw_beacon_response_time - |
7743 | ah->ah_config.ath_hal_dma_beacon_response_time) | 7746 | ah->ah_config.dma_beacon_response_time) |
7744 | - | 7747 | - |
7745 | ah->ah_config.ath_hal_additional_swba_backoff) * | 7748 | ah->ah_config.additional_swba_backoff) * |
7746 | 1024; | 7749 | 1024; |
7747 | REG_WRITE(ah, AR_QRDYTIMECFG(q), | 7750 | REG_WRITE(ah, AR_QRDYTIMECFG(q), |
7748 | value | AR_Q_RDYTIMECFG_EN); | 7751 | value | AR_Q_RDYTIMECFG_EN); |
@@ -8131,14 +8134,14 @@ ath9k_hw_setuprxdesc(struct ath_hal *ah, struct ath_desc *ds, | |||
8131 | u32 size, u32 flags) | 8134 | u32 size, u32 flags) |
8132 | { | 8135 | { |
8133 | struct ar5416_desc *ads = AR5416DESC(ds); | 8136 | struct ar5416_desc *ads = AR5416DESC(ds); |
8134 | struct hal_capabilities *pCap = &ah->ah_caps; | 8137 | struct ath9k_hw_capabilities *pCap = &ah->ah_caps; |
8135 | 8138 | ||
8136 | ads->ds_ctl1 = size & AR_BufLen; | 8139 | ads->ds_ctl1 = size & AR_BufLen; |
8137 | if (flags & ATH9K_RXDESC_INTREQ) | 8140 | if (flags & ATH9K_RXDESC_INTREQ) |
8138 | ads->ds_ctl1 |= AR_RxIntrReq; | 8141 | ads->ds_ctl1 |= AR_RxIntrReq; |
8139 | 8142 | ||
8140 | ads->ds_rxstatus8 &= ~AR_RxDone; | 8143 | ads->ds_rxstatus8 &= ~AR_RxDone; |
8141 | if (!pCap->halAutoSleepSupport) | 8144 | if (!(pCap->hw_caps & ATH9K_HW_CAP_AUTOSLEEP)) |
8142 | memset(&(ads->u), 0, sizeof(ads->u)); | 8145 | memset(&(ads->u), 0, sizeof(ads->u)); |
8143 | return true; | 8146 | return true; |
8144 | } | 8147 | } |
diff --git a/drivers/net/wireless/ath9k/main.c b/drivers/net/wireless/ath9k/main.c index 9549524630f7..01bee5ec7233 100644 --- a/drivers/net/wireless/ath9k/main.c +++ b/drivers/net/wireless/ath9k/main.c | |||
@@ -1268,14 +1268,14 @@ static int ath_attach(u16 devid, | |||
1268 | sc->rates[IEEE80211_BAND_2GHZ]; | 1268 | sc->rates[IEEE80211_BAND_2GHZ]; |
1269 | sc->sbands[IEEE80211_BAND_2GHZ].band = IEEE80211_BAND_2GHZ; | 1269 | sc->sbands[IEEE80211_BAND_2GHZ].band = IEEE80211_BAND_2GHZ; |
1270 | 1270 | ||
1271 | if (sc->sc_ah->ah_caps.halHTSupport) | 1271 | if (sc->sc_ah->ah_caps.hw_caps & ATH9K_HW_CAP_HT) |
1272 | /* Setup HT capabilities for 2.4Ghz*/ | 1272 | /* Setup HT capabilities for 2.4Ghz*/ |
1273 | setup_ht_cap(&sc->sbands[IEEE80211_BAND_2GHZ].ht_info); | 1273 | setup_ht_cap(&sc->sbands[IEEE80211_BAND_2GHZ].ht_info); |
1274 | 1274 | ||
1275 | hw->wiphy->bands[IEEE80211_BAND_2GHZ] = | 1275 | hw->wiphy->bands[IEEE80211_BAND_2GHZ] = |
1276 | &sc->sbands[IEEE80211_BAND_2GHZ]; | 1276 | &sc->sbands[IEEE80211_BAND_2GHZ]; |
1277 | 1277 | ||
1278 | if (sc->sc_ah->ah_caps.halWirelessModes & ATH9K_MODE_SEL_11A) { | 1278 | if (sc->sc_ah->ah_caps.wireless_modes & ATH9K_MODE_SEL_11A) { |
1279 | sc->sbands[IEEE80211_BAND_5GHZ].channels = | 1279 | sc->sbands[IEEE80211_BAND_5GHZ].channels = |
1280 | sc->channels[IEEE80211_BAND_5GHZ]; | 1280 | sc->channels[IEEE80211_BAND_5GHZ]; |
1281 | sc->sbands[IEEE80211_BAND_5GHZ].bitrates = | 1281 | sc->sbands[IEEE80211_BAND_5GHZ].bitrates = |
@@ -1283,7 +1283,7 @@ static int ath_attach(u16 devid, | |||
1283 | sc->sbands[IEEE80211_BAND_5GHZ].band = | 1283 | sc->sbands[IEEE80211_BAND_5GHZ].band = |
1284 | IEEE80211_BAND_5GHZ; | 1284 | IEEE80211_BAND_5GHZ; |
1285 | 1285 | ||
1286 | if (sc->sc_ah->ah_caps.halHTSupport) | 1286 | if (sc->sc_ah->ah_caps.hw_caps & ATH9K_HW_CAP_HT) |
1287 | /* Setup HT capabilities for 5Ghz*/ | 1287 | /* Setup HT capabilities for 5Ghz*/ |
1288 | setup_ht_cap(&sc->sbands[IEEE80211_BAND_5GHZ].ht_info); | 1288 | setup_ht_cap(&sc->sbands[IEEE80211_BAND_5GHZ].ht_info); |
1289 | 1289 | ||
diff --git a/drivers/net/wireless/ath9k/rc.c b/drivers/net/wireless/ath9k/rc.c index e0797afee52b..d3132009d94d 100644 --- a/drivers/net/wireless/ath9k/rc.c +++ b/drivers/net/wireless/ath9k/rc.c | |||
@@ -780,7 +780,7 @@ struct ath_rate_softc *ath_rate_attach(struct ath_hal *ah) | |||
780 | ar5416_attach_ratetables(asc); | 780 | ar5416_attach_ratetables(asc); |
781 | 781 | ||
782 | /* Save Maximum TX Trigger Level (used for 11n) */ | 782 | /* Save Maximum TX Trigger Level (used for 11n) */ |
783 | tx_triglevel_max = ah->ah_caps.halTxTrigLevelMax; | 783 | tx_triglevel_max = ah->ah_caps.tx_triglevel_max; |
784 | /* return alias for ath_rate_softc * */ | 784 | /* return alias for ath_rate_softc * */ |
785 | return asc; | 785 | return asc; |
786 | } | 786 | } |
diff --git a/drivers/net/wireless/ath9k/recv.c b/drivers/net/wireless/ath9k/recv.c index 8e14e643e994..2fe806175c01 100644 --- a/drivers/net/wireless/ath9k/recv.c +++ b/drivers/net/wireless/ath9k/recv.c | |||
@@ -478,7 +478,7 @@ static void ath_opmode_init(struct ath_softc *sc) | |||
478 | ath9k_hw_setrxfilter(ah, rfilt); | 478 | ath9k_hw_setrxfilter(ah, rfilt); |
479 | 479 | ||
480 | /* configure bssid mask */ | 480 | /* configure bssid mask */ |
481 | if (ah->ah_caps.halBssIdMaskSupport) | 481 | if (ah->ah_caps.hw_caps & ATH9K_HW_CAP_BSSIDMASK) |
482 | ath9k_hw_setbssidmask(ah, sc->sc_bssidmask); | 482 | ath9k_hw_setbssidmask(ah, sc->sc_bssidmask); |
483 | 483 | ||
484 | /* configure operational mode */ | 484 | /* configure operational mode */ |
@@ -1018,7 +1018,7 @@ int ath_rx_tasklet(struct ath_softc *sc, int flush) | |||
1018 | PCI_DMA_FROMDEVICE); | 1018 | PCI_DMA_FROMDEVICE); |
1019 | 1019 | ||
1020 | /* XXX: Ah! make me more readable, use a helper */ | 1020 | /* XXX: Ah! make me more readable, use a helper */ |
1021 | if (ah->ah_caps.halHTSupport) { | 1021 | if (ah->ah_caps.hw_caps & ATH9K_HW_CAP_HT) { |
1022 | if (ds->ds_rxstat.rs_moreaggr == 0) { | 1022 | if (ds->ds_rxstat.rs_moreaggr == 0) { |
1023 | rx_status.rssictl[0] = | 1023 | rx_status.rssictl[0] = |
1024 | ds->ds_rxstat.rs_rssi_ctl0; | 1024 | ds->ds_rxstat.rs_rssi_ctl0; |
diff --git a/drivers/net/wireless/ath9k/regd.c b/drivers/net/wireless/ath9k/regd.c index 7b0176e3eb40..05e10c485fa4 100644 --- a/drivers/net/wireless/ath9k/regd.c +++ b/drivers/net/wireless/ath9k/regd.c | |||
@@ -87,7 +87,7 @@ static bool ath9k_regd_is_fcc_midband_supported(struct ath_hal *ah) | |||
87 | { | 87 | { |
88 | u32 regcap; | 88 | u32 regcap; |
89 | 89 | ||
90 | regcap = ah->ah_caps.halRegCap; | 90 | regcap = ah->ah_caps.reg_cap; |
91 | 91 | ||
92 | if (regcap & AR_EEPROM_EEREGCAP_EN_FCC_MIDBAND) | 92 | if (regcap & AR_EEPROM_EEREGCAP_EN_FCC_MIDBAND) |
93 | return true; | 93 | return true; |
@@ -138,7 +138,7 @@ ath9k_regd_get_wmodes_nreg(struct ath_hal *ah, | |||
138 | { | 138 | { |
139 | u32 modesAvail; | 139 | u32 modesAvail; |
140 | 140 | ||
141 | modesAvail = ah->ah_caps.halWirelessModes; | 141 | modesAvail = ah->ah_caps.wireless_modes; |
142 | 142 | ||
143 | if ((modesAvail & ATH9K_MODE_SEL_11G) && (!country->allow11g)) | 143 | if ((modesAvail & ATH9K_MODE_SEL_11G) && (!country->allow11g)) |
144 | modesAvail &= ~ATH9K_MODE_SEL_11G; | 144 | modesAvail &= ~ATH9K_MODE_SEL_11G; |
@@ -436,7 +436,7 @@ ath9k_regd_add_channel(struct ath_hal *ah, | |||
436 | return false; | 436 | return false; |
437 | } | 437 | } |
438 | if ((fband->channelBW == CHANNEL_HALF_BW) && | 438 | if ((fband->channelBW == CHANNEL_HALF_BW) && |
439 | !ah->ah_caps.halChanHalfRate) { | 439 | !(ah->ah_caps.hw_caps & ATH9K_HW_CAP_CHAN_HALFRATE)) { |
440 | DPRINTF(ah->ah_sc, ATH_DBG_REGULATORY, | 440 | DPRINTF(ah->ah_sc, ATH_DBG_REGULATORY, |
441 | "%s: Skipping %u half rate channel\n", | 441 | "%s: Skipping %u half rate channel\n", |
442 | __func__, c); | 442 | __func__, c); |
@@ -444,7 +444,7 @@ ath9k_regd_add_channel(struct ath_hal *ah, | |||
444 | } | 444 | } |
445 | 445 | ||
446 | if ((fband->channelBW == CHANNEL_QUARTER_BW) && | 446 | if ((fband->channelBW == CHANNEL_QUARTER_BW) && |
447 | !ah->ah_caps.halChanQuarterRate) { | 447 | !(ah->ah_caps.hw_caps & ATH9K_HW_CAP_CHAN_QUARTERRATE)) { |
448 | DPRINTF(ah->ah_sc, ATH_DBG_REGULATORY, | 448 | DPRINTF(ah->ah_sc, ATH_DBG_REGULATORY, |
449 | "%s: Skipping %u quarter rate channel\n", | 449 | "%s: Skipping %u quarter rate channel\n", |
450 | __func__, c); | 450 | __func__, c); |
@@ -529,7 +529,7 @@ ath9k_regd_add_channel(struct ath_hal *ah, | |||
529 | if ((c < 2412) || (c > 2462)) { | 529 | if ((c < 2412) || (c > 2462)) { |
530 | if (rd5GHz.regDmnEnum == MKK1 || | 530 | if (rd5GHz.regDmnEnum == MKK1 || |
531 | rd5GHz.regDmnEnum == MKK2) { | 531 | rd5GHz.regDmnEnum == MKK2) { |
532 | u32 regcap = ah->ah_caps.halRegCap; | 532 | u32 regcap = ah->ah_caps.reg_cap; |
533 | if (!(regcap & | 533 | if (!(regcap & |
534 | (AR_EEPROM_EEREGCAP_EN_KK_U1_EVEN | | 534 | (AR_EEPROM_EEREGCAP_EN_KK_U1_EVEN | |
535 | AR_EEPROM_EEREGCAP_EN_KK_U2 | | 535 | AR_EEPROM_EEREGCAP_EN_KK_U2 | |
@@ -594,7 +594,7 @@ static bool ath9k_regd_japan_check(struct ath_hal *ah, | |||
594 | 594 | ||
595 | for (i = 0; i < ARRAY_SIZE(j_bandcheck); i++) { | 595 | for (i = 0; i < ARRAY_SIZE(j_bandcheck); i++) { |
596 | if (j_bandcheck[i].freqbandbit == b) { | 596 | if (j_bandcheck[i].freqbandbit == b) { |
597 | regcap = ah->ah_caps.halRegCap; | 597 | regcap = ah->ah_caps.reg_cap; |
598 | if ((j_bandcheck[i].eepromflagtocheck & regcap) == 0) { | 598 | if ((j_bandcheck[i].eepromflagtocheck & regcap) == 0) { |
599 | skipband = true; | 599 | skipband = true; |
600 | } else if ((regcap & AR_EEPROM_EEREGCAP_EN_KK_U2) || | 600 | } else if ((regcap & AR_EEPROM_EEREGCAP_EN_KK_U2) || |
@@ -726,7 +726,7 @@ ath9k_regd_init_channels(struct ath_hal *ah, | |||
726 | } | 726 | } |
727 | 727 | ||
728 | if (country == NULL) { | 728 | if (country == NULL) { |
729 | modesAvail = ah->ah_caps.halWirelessModes; | 729 | modesAvail = ah->ah_caps.wireless_modes; |
730 | } else { | 730 | } else { |
731 | modesAvail = ath9k_regd_get_wmodes_nreg(ah, country, &rd5GHz); | 731 | modesAvail = ath9k_regd_get_wmodes_nreg(ah, country, &rd5GHz); |
732 | if (!enableOutdoor) | 732 | if (!enableOutdoor) |
diff --git a/drivers/net/wireless/ath9k/xmit.c b/drivers/net/wireless/ath9k/xmit.c index f0297ee5d053..92bb3c22e7c2 100644 --- a/drivers/net/wireless/ath9k/xmit.c +++ b/drivers/net/wireless/ath9k/xmit.c | |||
@@ -781,7 +781,7 @@ static void ath_buf_set_rate(struct ath_softc *sc, struct ath_buf *bf) | |||
781 | * let rate series flags determine which rates will actually | 781 | * let rate series flags determine which rates will actually |
782 | * use RTS. | 782 | * use RTS. |
783 | */ | 783 | */ |
784 | if (ah->ah_caps.halHTSupport && bf->bf_isdata) { | 784 | if ((ah->ah_caps.hw_caps & ATH9K_HW_CAP_HT) && bf->bf_isdata) { |
785 | BUG_ON(!an); | 785 | BUG_ON(!an); |
786 | /* | 786 | /* |
787 | * 802.11g protection not needed, use our default behavior | 787 | * 802.11g protection not needed, use our default behavior |
@@ -897,7 +897,7 @@ static void ath_buf_set_rate(struct ath_softc *sc, struct ath_buf *bf) | |||
897 | * For non-HT devices, calculate RTS/CTS duration in software | 897 | * For non-HT devices, calculate RTS/CTS duration in software |
898 | * and disable multi-rate retry. | 898 | * and disable multi-rate retry. |
899 | */ | 899 | */ |
900 | if (flags && !ah->ah_caps.halHTSupport) { | 900 | if (flags && !(ah->ah_caps.hw_caps & ATH9K_HW_CAP_HT)) { |
901 | /* | 901 | /* |
902 | * Compute the transmit duration based on the frame | 902 | * Compute the transmit duration based on the frame |
903 | * size and the size of an ACK frame. We call into the | 903 | * size and the size of an ACK frame. We call into the |