aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/ath
diff options
context:
space:
mode:
authorFelix Fietkau <nbd@openwrt.org>2011-03-19 08:55:42 -0400
committerJohn W. Linville <linville@tuxdriver.com>2011-03-30 14:15:16 -0400
commit598cdd5246ea158310942699e5008ac7f687ad62 (patch)
treea1ddf05181b6e98b06870e00f6adb737297275ee /drivers/net/wireless/ath
parentf171760c558946c7a2e0ee310dfb968f9d4853c6 (diff)
ath9k_hw: force rx chainmask to 7 on AR9100
Most AR9100 devices already have a chainmask of 7 (three antennas), however on the ones that don't (rx and tx chainmask set to 5), problems with IQ mismatch calibration have been observed. This shows up as tx queue hangs (and subsequent hardware resets) if traffic is sent during this type of calibration. Forcing the rx chainmask to 7 fixes the calibration issues with no apparent negative side effects on throughput and stability. Signed-off-by: Felix Fietkau <nbd@openwrt.org> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/ath')
-rw-r--r--drivers/net/wireless/ath/ath9k/hw.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/net/wireless/ath/ath9k/hw.c b/drivers/net/wireless/ath/ath9k/hw.c
index 175c36f3fdac..8b8656898dfe 100644
--- a/drivers/net/wireless/ath/ath9k/hw.c
+++ b/drivers/net/wireless/ath/ath9k/hw.c
@@ -1869,6 +1869,8 @@ int ath9k_hw_fill_cap_info(struct ath_hw *ah)
1869 !(AR_SREV_9271(ah))) 1869 !(AR_SREV_9271(ah)))
1870 /* CB71: GPIO 0 is pulled down to indicate 3 rx chains */ 1870 /* CB71: GPIO 0 is pulled down to indicate 3 rx chains */
1871 pCap->rx_chainmask = ath9k_hw_gpio_get(ah, 0) ? 0x5 : 0x7; 1871 pCap->rx_chainmask = ath9k_hw_gpio_get(ah, 0) ? 0x5 : 0x7;
1872 else if (AR_SREV_9100(ah))
1873 pCap->rx_chainmask = 0x7;
1872 else 1874 else
1873 /* Use rx_chainmask from EEPROM. */ 1875 /* Use rx_chainmask from EEPROM. */
1874 pCap->rx_chainmask = ah->eep_ops->get_eeprom(ah, EEP_RX_MASK); 1876 pCap->rx_chainmask = ah->eep_ops->get_eeprom(ah, EEP_RX_MASK);