07e78d3b30c92d6aae1a9e4ea8b6d4a4c6a81fcb
[openwrt.git] / package / mac80211 / patches / 580-ath9k_fixup_chainmask.patch
1 --- a/drivers/net/wireless/ath/ath9k/hw.c
2 +++ b/drivers/net/wireless/ath/ath9k/hw.c
3 @@ -2007,12 +2007,22 @@ EXPORT_SYMBOL(ath9k_hw_set_sta_beacon_ti
4  /* HW Capabilities */
5  /*******************/
6  
7 +static u8 fixup_chainmask(u8 chip_chainmask, u8 eeprom_chainmask)
8 +{
9 +       eeprom_chainmask &= chip_chainmask;
10 +       if (eeprom_chainmask)
11 +               return eeprom_chainmask;
12 +       else
13 +               return chip_chainmask;
14 +}
15 +
16  int ath9k_hw_fill_cap_info(struct ath_hw *ah)
17  {
18         struct ath9k_hw_capabilities *pCap = &ah->caps;
19         struct ath_regulatory *regulatory = ath9k_hw_regulatory(ah);
20         struct ath_common *common = ath9k_hw_common(ah);
21         struct ath_btcoex_hw *btcoex_hw = &ah->btcoex_hw;
22 +       unsigned int chip_chainmask;
23  
24         u16 eeval;
25         u8 ant_div_ctl1, tx_chainmask, rx_chainmask;
26 @@ -2049,6 +2059,15 @@ int ath9k_hw_fill_cap_info(struct ath_hw
27         if (eeval & AR5416_OPFLAGS_11G)
28                 pCap->hw_caps |= ATH9K_HW_CAP_2GHZ;
29  
30 +       if (AR_SREV_9485(ah) || AR_SREV_9285(ah) || AR_SREV_9330(ah))
31 +               chip_chainmask = 1;
32 +       else if (!AR_SREV_9280_20_OR_LATER(ah))
33 +               chip_chainmask = 7;
34 +       else if (!AR_SREV_9300_20_OR_LATER(ah) || AR_SREV_9340(ah))
35 +               chip_chainmask = 3;
36 +       else
37 +               chip_chainmask = 7;
38 +
39         pCap->tx_chainmask = ah->eep_ops->get_eeprom(ah, EEP_TX_MASK);
40         /*
41          * For AR9271 we will temporarilly uses the rx chainmax as read from
42 @@ -2065,6 +2084,9 @@ int ath9k_hw_fill_cap_info(struct ath_hw
43                 /* Use rx_chainmask from EEPROM. */
44                 pCap->rx_chainmask = ah->eep_ops->get_eeprom(ah, EEP_RX_MASK);
45  
46 +       pCap->tx_chainmask = fixup_chainmask(chip_chainmask, pCap->tx_chainmask);
47 +       pCap->rx_chainmask = fixup_chainmask(chip_chainmask, pCap->rx_chainmask);
48 +
49         ah->misc_mode |= AR_PCU_MIC_NEW_LOC_ENA;
50  
51         /* enable key search for every frame in an aggregate */