root/drivers/net/wireless/ath/ath9k/ar9003_hw.c

/* [<][>][^][v][top][bottom][index][help] */

DEFINITIONS

This source file includes following definitions.
  1. ar9003_hw_init_mode_regs
  2. ar9003_tx_gain_table_mode0
  3. ar9003_tx_gain_table_mode1
  4. ar9003_tx_gain_table_mode2
  5. ar9003_tx_gain_table_mode3
  6. ar9003_tx_gain_table_mode4
  7. ar9003_tx_gain_table_mode5
  8. ar9003_tx_gain_table_mode6
  9. ar9003_tx_gain_table_mode7
  10. ar9003_tx_gain_table_apply
  11. ar9003_rx_gain_table_mode0
  12. ar9003_rx_gain_table_mode1
  13. ar9003_rx_gain_table_mode2
  14. ar9003_rx_gain_table_mode3
  15. ar9003_rx_gain_table_apply
  16. ar9003_hw_init_mode_gain_regs
  17. ar9003_hw_configpcipowersave
  18. ar9003_hw_init_hang_checks
  19. ath9k_hw_verify_hang
  20. ar9003_hw_detect_mac_hang
  21. ar9003_hw_attach_ops

   1 /*
   2  * Copyright (c) 2008-2011 Atheros Communications Inc.
   3  *
   4  * Permission to use, copy, modify, and/or distribute this software for any
   5  * purpose with or without fee is hereby granted, provided that the above
   6  * copyright notice and this permission notice appear in all copies.
   7  *
   8  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
   9  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
  10  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
  11  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
  12  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
  13  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
  14  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  15  */
  16 
  17 #include "hw.h"
  18 #include "ar9003_mac.h"
  19 #include "ar9003_2p2_initvals.h"
  20 #include "ar9003_buffalo_initvals.h"
  21 #include "ar9485_initvals.h"
  22 #include "ar9340_initvals.h"
  23 #include "ar9330_1p1_initvals.h"
  24 #include "ar9330_1p2_initvals.h"
  25 #include "ar955x_1p0_initvals.h"
  26 #include "ar9580_1p0_initvals.h"
  27 #include "ar9462_2p0_initvals.h"
  28 #include "ar9462_2p1_initvals.h"
  29 #include "ar9565_1p0_initvals.h"
  30 #include "ar9565_1p1_initvals.h"
  31 #include "ar953x_initvals.h"
  32 #include "ar956x_initvals.h"
  33 
  34 /* General hardware code for the AR9003 hadware family */
  35 
  36 /*
  37  * The AR9003 family uses a new INI format (pre, core, post
  38  * arrays per subsystem). This provides support for the
  39  * AR9003 2.2 chipsets.
  40  */
  41 static void ar9003_hw_init_mode_regs(struct ath_hw *ah)
  42 {
  43         if (AR_SREV_9330_11(ah)) {
  44                 /* mac */
  45                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
  46                                 ar9331_1p1_mac_core);
  47                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
  48                                 ar9331_1p1_mac_postamble);
  49 
  50                 /* bb */
  51                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
  52                                 ar9331_1p1_baseband_core);
  53                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
  54                                 ar9331_1p1_baseband_postamble);
  55 
  56                 /* radio */
  57                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
  58                                 ar9331_1p1_radio_core);
  59 
  60                 /* soc */
  61                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
  62                                 ar9331_1p1_soc_preamble);
  63                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
  64                                 ar9331_1p1_soc_postamble);
  65 
  66                 /* rx/tx gain */
  67                 INIT_INI_ARRAY(&ah->iniModesRxGain,
  68                                 ar9331_common_rx_gain_1p1);
  69                 INIT_INI_ARRAY(&ah->iniModesTxGain,
  70                                 ar9331_modes_lowest_ob_db_tx_gain_1p1);
  71 
  72                 /* Japan 2484 Mhz CCK */
  73                 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
  74                                ar9331_1p1_baseband_core_txfir_coeff_japan_2484);
  75 
  76                 /* additional clock settings */
  77                 if (ah->is_clk_25mhz)
  78                         INIT_INI_ARRAY(&ah->iniAdditional,
  79                                         ar9331_1p1_xtal_25M);
  80                 else
  81                         INIT_INI_ARRAY(&ah->iniAdditional,
  82                                         ar9331_1p1_xtal_40M);
  83         } else if (AR_SREV_9330_12(ah)) {
  84                 /* mac */
  85                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
  86                                 ar9331_1p2_mac_core);
  87                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
  88                                 ar9331_1p2_mac_postamble);
  89 
  90                 /* bb */
  91                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
  92                                 ar9331_1p2_baseband_core);
  93                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
  94                                 ar9331_1p2_baseband_postamble);
  95 
  96                 /* radio */
  97                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
  98                                 ar9331_1p2_radio_core);
  99 
 100                 /* soc */
 101                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
 102                                 ar9331_1p2_soc_preamble);
 103                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
 104                                 ar9331_1p2_soc_postamble);
 105 
 106                 /* rx/tx gain */
 107                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 108                                 ar9331_common_rx_gain_1p2);
 109                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 110                                 ar9331_modes_lowest_ob_db_tx_gain_1p2);
 111 
 112                 /* Japan 2484 Mhz CCK */
 113                 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
 114                                ar9331_1p2_baseband_core_txfir_coeff_japan_2484);
 115 
 116                 /* additional clock settings */
 117                 if (ah->is_clk_25mhz)
 118                         INIT_INI_ARRAY(&ah->iniAdditional,
 119                                         ar9331_1p2_xtal_25M);
 120                 else
 121                         INIT_INI_ARRAY(&ah->iniAdditional,
 122                                         ar9331_1p2_xtal_40M);
 123         } else if (AR_SREV_9340(ah)) {
 124                 /* mac */
 125                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
 126                                 ar9340_1p0_mac_core);
 127                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
 128                                 ar9340_1p0_mac_postamble);
 129 
 130                 /* bb */
 131                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
 132                                 ar9340_1p0_baseband_core);
 133                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
 134                                 ar9340_1p0_baseband_postamble);
 135 
 136                 /* radio */
 137                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
 138                                 ar9340_1p0_radio_core);
 139                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
 140                                 ar9340_1p0_radio_postamble);
 141 
 142                 /* soc */
 143                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
 144                                 ar9340_1p0_soc_preamble);
 145                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
 146                                 ar9340_1p0_soc_postamble);
 147 
 148                 /* rx/tx gain */
 149                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 150                                 ar9340Common_wo_xlna_rx_gain_table_1p0);
 151                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 152                                 ar9340Modes_high_ob_db_tx_gain_table_1p0);
 153 
 154                 INIT_INI_ARRAY(&ah->iniModesFastClock,
 155                                ar9340Modes_fast_clock_1p0);
 156                 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
 157                                ar9340_1p0_baseband_core_txfir_coeff_japan_2484);
 158                 INIT_INI_ARRAY(&ah->ini_dfs,
 159                                ar9340_1p0_baseband_postamble_dfs_channel);
 160 
 161                 if (!ah->is_clk_25mhz)
 162                         INIT_INI_ARRAY(&ah->iniAdditional,
 163                                        ar9340_1p0_radio_core_40M);
 164         } else if (AR_SREV_9485_11_OR_LATER(ah)) {
 165                 /* mac */
 166                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
 167                                 ar9485_1_1_mac_core);
 168                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
 169                                 ar9485_1_1_mac_postamble);
 170 
 171                 /* bb */
 172                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_PRE], ar9485_1_1);
 173                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
 174                                 ar9485_1_1_baseband_core);
 175                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
 176                                 ar9485_1_1_baseband_postamble);
 177 
 178                 /* radio */
 179                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
 180                                 ar9485_1_1_radio_core);
 181                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
 182                                 ar9485_1_1_radio_postamble);
 183 
 184                 /* soc */
 185                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
 186                                 ar9485_1_1_soc_preamble);
 187 
 188                 /* rx/tx gain */
 189                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 190                                 ar9485Common_wo_xlna_rx_gain_1_1);
 191                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 192                                 ar9485_modes_lowest_ob_db_tx_gain_1_1);
 193 
 194                 /* Japan 2484 Mhz CCK */
 195                 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
 196                                ar9485_1_1_baseband_core_txfir_coeff_japan_2484);
 197 
 198                 if (ah->config.pll_pwrsave & AR_PCIE_PLL_PWRSAVE_CONTROL) {
 199                         INIT_INI_ARRAY(&ah->iniPcieSerdes,
 200                                        ar9485_1_1_pll_on_cdr_on_clkreq_disable_L1);
 201                         INIT_INI_ARRAY(&ah->iniPcieSerdesLowPower,
 202                                        ar9485_1_1_pll_on_cdr_on_clkreq_disable_L1);
 203                 } else {
 204                         INIT_INI_ARRAY(&ah->iniPcieSerdes,
 205                                        ar9485_1_1_pcie_phy_clkreq_disable_L1);
 206                         INIT_INI_ARRAY(&ah->iniPcieSerdesLowPower,
 207                                        ar9485_1_1_pcie_phy_clkreq_disable_L1);
 208                 }
 209         } else if (AR_SREV_9462_21(ah)) {
 210                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
 211                                ar9462_2p1_mac_core);
 212                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
 213                                ar9462_2p1_mac_postamble);
 214                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
 215                                ar9462_2p1_baseband_core);
 216                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
 217                                ar9462_2p1_baseband_postamble);
 218                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
 219                                ar9462_2p1_radio_core);
 220                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
 221                                ar9462_2p1_radio_postamble);
 222                 INIT_INI_ARRAY(&ah->ini_radio_post_sys2ant,
 223                                ar9462_2p1_radio_postamble_sys2ant);
 224                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
 225                                ar9462_2p1_soc_preamble);
 226                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
 227                                ar9462_2p1_soc_postamble);
 228                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 229                                ar9462_2p1_common_rx_gain);
 230                 INIT_INI_ARRAY(&ah->iniModesFastClock,
 231                                ar9462_2p1_modes_fast_clock);
 232                 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
 233                                ar9462_2p1_baseband_core_txfir_coeff_japan_2484);
 234 
 235                 /* Awake -> Sleep Setting */
 236                 if ((ah->config.pll_pwrsave & AR_PCIE_PLL_PWRSAVE_CONTROL) &&
 237                     (ah->config.pll_pwrsave & AR_PCIE_PLL_PWRSAVE_ON_D3)) {
 238                         INIT_INI_ARRAY(&ah->iniPcieSerdes,
 239                                        ar9462_2p1_pciephy_clkreq_disable_L1);
 240                 }
 241 
 242                 /* Sleep -> Awake Setting */
 243                 if ((ah->config.pll_pwrsave & AR_PCIE_PLL_PWRSAVE_CONTROL) &&
 244                     (ah->config.pll_pwrsave & AR_PCIE_PLL_PWRSAVE_ON_D0)) {
 245                         INIT_INI_ARRAY(&ah->iniPcieSerdesLowPower,
 246                                        ar9462_2p1_pciephy_clkreq_disable_L1);
 247                 }
 248         } else if (AR_SREV_9462_20(ah)) {
 249 
 250                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE], ar9462_2p0_mac_core);
 251                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
 252                                 ar9462_2p0_mac_postamble);
 253 
 254                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
 255                                 ar9462_2p0_baseband_core);
 256                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
 257                                 ar9462_2p0_baseband_postamble);
 258 
 259                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
 260                                 ar9462_2p0_radio_core);
 261                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
 262                                 ar9462_2p0_radio_postamble);
 263                 INIT_INI_ARRAY(&ah->ini_radio_post_sys2ant,
 264                                 ar9462_2p0_radio_postamble_sys2ant);
 265 
 266                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
 267                                 ar9462_2p0_soc_preamble);
 268                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
 269                                 ar9462_2p0_soc_postamble);
 270 
 271                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 272                                 ar9462_2p0_common_rx_gain);
 273 
 274                 /* Awake -> Sleep Setting */
 275                 if ((ah->config.pll_pwrsave & AR_PCIE_PLL_PWRSAVE_CONTROL) &&
 276                     (ah->config.pll_pwrsave & AR_PCIE_PLL_PWRSAVE_ON_D3)) {
 277                         INIT_INI_ARRAY(&ah->iniPcieSerdes,
 278                                        ar9462_2p0_pciephy_clkreq_disable_L1);
 279                 }
 280 
 281                 /* Sleep -> Awake Setting */
 282                 if ((ah->config.pll_pwrsave & AR_PCIE_PLL_PWRSAVE_CONTROL) &&
 283                     (ah->config.pll_pwrsave & AR_PCIE_PLL_PWRSAVE_ON_D0)) {
 284                         INIT_INI_ARRAY(&ah->iniPcieSerdesLowPower,
 285                                        ar9462_2p0_pciephy_clkreq_disable_L1);
 286                 }
 287 
 288                 /* Fast clock modal settings */
 289                 INIT_INI_ARRAY(&ah->iniModesFastClock,
 290                                 ar9462_2p0_modes_fast_clock);
 291 
 292                 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
 293                                ar9462_2p0_baseband_core_txfir_coeff_japan_2484);
 294         } else if (AR_SREV_9550(ah)) {
 295                 /* mac */
 296                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
 297                                 ar955x_1p0_mac_core);
 298                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
 299                                 ar955x_1p0_mac_postamble);
 300 
 301                 /* bb */
 302                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
 303                                 ar955x_1p0_baseband_core);
 304                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
 305                                 ar955x_1p0_baseband_postamble);
 306 
 307                 /* radio */
 308                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
 309                                 ar955x_1p0_radio_core);
 310                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
 311                                 ar955x_1p0_radio_postamble);
 312 
 313                 /* soc */
 314                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
 315                                 ar955x_1p0_soc_preamble);
 316                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
 317                                 ar955x_1p0_soc_postamble);
 318 
 319                 /* rx/tx gain */
 320                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 321                         ar955x_1p0_common_wo_xlna_rx_gain_table);
 322                 INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
 323                         ar955x_1p0_common_wo_xlna_rx_gain_bounds);
 324                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 325                                 ar955x_1p0_modes_xpa_tx_gain_table);
 326 
 327                 /* Fast clock modal settings */
 328                 INIT_INI_ARRAY(&ah->iniModesFastClock,
 329                                 ar955x_1p0_modes_fast_clock);
 330         } else if (AR_SREV_9531(ah)) {
 331                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
 332                                qca953x_1p0_mac_core);
 333                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
 334                                qca953x_1p0_mac_postamble);
 335                 if (AR_SREV_9531_20(ah)) {
 336                         INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
 337                                        qca953x_2p0_baseband_core);
 338                         INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
 339                                        qca953x_2p0_baseband_postamble);
 340                 } else {
 341                         INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
 342                                        qca953x_1p0_baseband_core);
 343                         INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
 344                                        qca953x_1p0_baseband_postamble);
 345                 }
 346                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
 347                                qca953x_1p0_radio_core);
 348                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
 349                                qca953x_1p0_radio_postamble);
 350                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
 351                                qca953x_1p0_soc_preamble);
 352                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
 353                                qca953x_1p0_soc_postamble);
 354 
 355                 if (AR_SREV_9531_20(ah)) {
 356                         INIT_INI_ARRAY(&ah->iniModesRxGain,
 357                                        qca953x_2p0_common_wo_xlna_rx_gain_table);
 358                         INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
 359                                        qca953x_2p0_common_wo_xlna_rx_gain_bounds);
 360                 } else {
 361                         INIT_INI_ARRAY(&ah->iniModesRxGain,
 362                                        qca953x_1p0_common_wo_xlna_rx_gain_table);
 363                         INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
 364                                        qca953x_1p0_common_wo_xlna_rx_gain_bounds);
 365                 }
 366 
 367                 if (AR_SREV_9531_20(ah))
 368                         INIT_INI_ARRAY(&ah->iniModesTxGain,
 369                                        qca953x_2p0_modes_no_xpa_tx_gain_table);
 370                 else if (AR_SREV_9531_11(ah))
 371                         INIT_INI_ARRAY(&ah->iniModesTxGain,
 372                                        qca953x_1p1_modes_no_xpa_tx_gain_table);
 373                 else
 374                         INIT_INI_ARRAY(&ah->iniModesTxGain,
 375                                        qca953x_1p0_modes_no_xpa_tx_gain_table);
 376 
 377                 INIT_INI_ARRAY(&ah->iniModesFastClock,
 378                                qca953x_1p0_modes_fast_clock);
 379         } else if (AR_SREV_9561(ah)) {
 380                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
 381                                qca956x_1p0_mac_core);
 382                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
 383                                qca956x_1p0_mac_postamble);
 384 
 385                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
 386                                qca956x_1p0_baseband_core);
 387                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
 388                                qca956x_1p0_baseband_postamble);
 389 
 390                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
 391                                qca956x_1p0_radio_core);
 392                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
 393                                qca956x_1p0_radio_postamble);
 394 
 395                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
 396                                qca956x_1p0_soc_preamble);
 397                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
 398                                qca956x_1p0_soc_postamble);
 399 
 400                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 401                                qca956x_1p0_common_wo_xlna_rx_gain_table);
 402                 INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
 403                                qca956x_1p0_common_wo_xlna_rx_gain_bounds);
 404                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 405                                qca956x_1p0_modes_no_xpa_tx_gain_table);
 406 
 407                 INIT_INI_ARRAY(&ah->ini_dfs,
 408                                qca956x_1p0_baseband_postamble_dfs_channel);
 409                 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
 410                                qca956x_1p0_baseband_core_txfir_coeff_japan_2484);
 411                 INIT_INI_ARRAY(&ah->iniModesFastClock,
 412                                qca956x_1p0_modes_fast_clock);
 413         } else if (AR_SREV_9580(ah)) {
 414                 /* mac */
 415                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
 416                                 ar9580_1p0_mac_core);
 417                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
 418                                 ar9580_1p0_mac_postamble);
 419 
 420                 /* bb */
 421                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
 422                                 ar9580_1p0_baseband_core);
 423                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
 424                                 ar9580_1p0_baseband_postamble);
 425 
 426                 /* radio */
 427                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
 428                                 ar9580_1p0_radio_core);
 429                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
 430                                 ar9580_1p0_radio_postamble);
 431 
 432                 /* soc */
 433                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
 434                                 ar9580_1p0_soc_preamble);
 435                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
 436                                 ar9580_1p0_soc_postamble);
 437 
 438                 /* rx/tx gain */
 439                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 440                                 ar9580_1p0_rx_gain_table);
 441                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 442                                 ar9580_1p0_low_ob_db_tx_gain_table);
 443 
 444                 INIT_INI_ARRAY(&ah->iniModesFastClock,
 445                                ar9580_1p0_modes_fast_clock);
 446                 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
 447                                ar9580_1p0_baseband_core_txfir_coeff_japan_2484);
 448                 INIT_INI_ARRAY(&ah->ini_dfs,
 449                                ar9580_1p0_baseband_postamble_dfs_channel);
 450         } else if (AR_SREV_9565_11_OR_LATER(ah)) {
 451                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
 452                                ar9565_1p1_mac_core);
 453                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
 454                                ar9565_1p1_mac_postamble);
 455 
 456                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
 457                                ar9565_1p1_baseband_core);
 458                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
 459                                ar9565_1p1_baseband_postamble);
 460 
 461                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
 462                                ar9565_1p1_radio_core);
 463                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
 464                                ar9565_1p1_radio_postamble);
 465 
 466                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
 467                                ar9565_1p1_soc_preamble);
 468                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
 469                                ar9565_1p1_soc_postamble);
 470 
 471                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 472                                ar9565_1p1_Common_rx_gain_table);
 473                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 474                                ar9565_1p1_Modes_lowest_ob_db_tx_gain_table);
 475 
 476                 /* Awake -> Sleep Setting */
 477                 if ((ah->config.pll_pwrsave & AR_PCIE_PLL_PWRSAVE_CONTROL) &&
 478                     (ah->config.pll_pwrsave & AR_PCIE_PLL_PWRSAVE_ON_D3)) {
 479                         INIT_INI_ARRAY(&ah->iniPcieSerdes,
 480                                        ar9565_1p1_pciephy_clkreq_disable_L1);
 481                 }
 482 
 483                 /* Sleep -> Awake Setting */
 484                 if ((ah->config.pll_pwrsave & AR_PCIE_PLL_PWRSAVE_CONTROL) &&
 485                     (ah->config.pll_pwrsave & AR_PCIE_PLL_PWRSAVE_ON_D0)) {
 486                         INIT_INI_ARRAY(&ah->iniPcieSerdesLowPower,
 487                                        ar9565_1p1_pciephy_clkreq_disable_L1);
 488                 }
 489 
 490                 INIT_INI_ARRAY(&ah->iniModesFastClock,
 491                                 ar9565_1p1_modes_fast_clock);
 492                 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
 493                                ar9565_1p1_baseband_core_txfir_coeff_japan_2484);
 494         } else if (AR_SREV_9565(ah)) {
 495                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
 496                                ar9565_1p0_mac_core);
 497                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
 498                                ar9565_1p0_mac_postamble);
 499 
 500                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
 501                                ar9565_1p0_baseband_core);
 502                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
 503                                ar9565_1p0_baseband_postamble);
 504 
 505                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
 506                                ar9565_1p0_radio_core);
 507                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
 508                                ar9565_1p0_radio_postamble);
 509 
 510                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
 511                                ar9565_1p0_soc_preamble);
 512                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
 513                                ar9565_1p0_soc_postamble);
 514 
 515                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 516                                ar9565_1p0_Common_rx_gain_table);
 517                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 518                                ar9565_1p0_Modes_lowest_ob_db_tx_gain_table);
 519 
 520                 /* Awake -> Sleep Setting */
 521                 if ((ah->config.pll_pwrsave & AR_PCIE_PLL_PWRSAVE_CONTROL) &&
 522                     (ah->config.pll_pwrsave & AR_PCIE_PLL_PWRSAVE_ON_D3)) {
 523                         INIT_INI_ARRAY(&ah->iniPcieSerdes,
 524                                        ar9565_1p0_pciephy_clkreq_disable_L1);
 525                 }
 526 
 527                 /* Sleep -> Awake Setting */
 528                 if ((ah->config.pll_pwrsave & AR_PCIE_PLL_PWRSAVE_CONTROL) &&
 529                     (ah->config.pll_pwrsave & AR_PCIE_PLL_PWRSAVE_ON_D0)) {
 530                         INIT_INI_ARRAY(&ah->iniPcieSerdesLowPower,
 531                                        ar9565_1p0_pciephy_clkreq_disable_L1);
 532                 }
 533 
 534                 INIT_INI_ARRAY(&ah->iniModesFastClock,
 535                                 ar9565_1p0_modes_fast_clock);
 536                 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
 537                                ar9565_1p0_baseband_core_txfir_coeff_japan_2484);
 538         } else {
 539                 /* mac */
 540                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
 541                                 ar9300_2p2_mac_core);
 542                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
 543                                 ar9300_2p2_mac_postamble);
 544 
 545                 /* bb */
 546                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
 547                                 ar9300_2p2_baseband_core);
 548                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
 549                                 ar9300_2p2_baseband_postamble);
 550 
 551                 /* radio */
 552                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
 553                                 ar9300_2p2_radio_core);
 554                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
 555                                 ar9300_2p2_radio_postamble);
 556 
 557                 /* soc */
 558                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
 559                                 ar9300_2p2_soc_preamble);
 560                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
 561                                 ar9300_2p2_soc_postamble);
 562 
 563                 /* rx/tx gain */
 564                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 565                                 ar9300Common_rx_gain_table_2p2);
 566                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 567                                 ar9300Modes_lowest_ob_db_tx_gain_table_2p2);
 568 
 569                 /* Load PCIE SERDES settings from INI */
 570 
 571                 /* Awake Setting */
 572 
 573                 INIT_INI_ARRAY(&ah->iniPcieSerdes,
 574                                 ar9300PciePhy_pll_on_clkreq_disable_L1_2p2);
 575 
 576                 /* Sleep Setting */
 577 
 578                 INIT_INI_ARRAY(&ah->iniPcieSerdesLowPower,
 579                                 ar9300PciePhy_pll_on_clkreq_disable_L1_2p2);
 580 
 581                 /* Fast clock modal settings */
 582                 INIT_INI_ARRAY(&ah->iniModesFastClock,
 583                                ar9300Modes_fast_clock_2p2);
 584                 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
 585                                ar9300_2p2_baseband_core_txfir_coeff_japan_2484);
 586                 INIT_INI_ARRAY(&ah->ini_dfs,
 587                                ar9300_2p2_baseband_postamble_dfs_channel);
 588         }
 589 }
 590 
 591 static void ar9003_tx_gain_table_mode0(struct ath_hw *ah)
 592 {
 593         if (AR_SREV_9330_12(ah))
 594                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 595                         ar9331_modes_lowest_ob_db_tx_gain_1p2);
 596         else if (AR_SREV_9330_11(ah))
 597                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 598                         ar9331_modes_lowest_ob_db_tx_gain_1p1);
 599         else if (AR_SREV_9340(ah))
 600                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 601                         ar9340Modes_lowest_ob_db_tx_gain_table_1p0);
 602         else if (AR_SREV_9485_11_OR_LATER(ah))
 603                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 604                         ar9485_modes_lowest_ob_db_tx_gain_1_1);
 605         else if (AR_SREV_9550(ah))
 606                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 607                         ar955x_1p0_modes_xpa_tx_gain_table);
 608         else if (AR_SREV_9531_10(ah))
 609                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 610                                qca953x_1p0_modes_xpa_tx_gain_table);
 611         else if (AR_SREV_9531_11(ah))
 612                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 613                                qca953x_1p1_modes_xpa_tx_gain_table);
 614         else if (AR_SREV_9531_20(ah))
 615                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 616                                qca953x_2p0_modes_xpa_tx_gain_table);
 617         else if (AR_SREV_9561(ah))
 618                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 619                                qca956x_1p0_modes_xpa_tx_gain_table);
 620         else if (AR_SREV_9580(ah))
 621                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 622                         ar9580_1p0_lowest_ob_db_tx_gain_table);
 623         else if (AR_SREV_9462_21(ah))
 624                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 625                         ar9462_2p1_modes_low_ob_db_tx_gain);
 626         else if (AR_SREV_9462_20(ah))
 627                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 628                         ar9462_2p0_modes_low_ob_db_tx_gain);
 629         else if (AR_SREV_9565_11(ah))
 630                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 631                                ar9565_1p1_modes_low_ob_db_tx_gain_table);
 632         else if (AR_SREV_9565(ah))
 633                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 634                                ar9565_1p0_modes_low_ob_db_tx_gain_table);
 635         else
 636                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 637                         ar9300Modes_lowest_ob_db_tx_gain_table_2p2);
 638 }
 639 
 640 static void ar9003_tx_gain_table_mode1(struct ath_hw *ah)
 641 {
 642         if (AR_SREV_9330_12(ah))
 643                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 644                         ar9331_modes_high_ob_db_tx_gain_1p2);
 645         else if (AR_SREV_9330_11(ah))
 646                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 647                         ar9331_modes_high_ob_db_tx_gain_1p1);
 648         else if (AR_SREV_9340(ah))
 649                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 650                         ar9340Modes_high_ob_db_tx_gain_table_1p0);
 651         else if (AR_SREV_9485_11_OR_LATER(ah))
 652                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 653                         ar9485Modes_high_ob_db_tx_gain_1_1);
 654         else if (AR_SREV_9580(ah))
 655                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 656                         ar9580_1p0_high_ob_db_tx_gain_table);
 657         else if (AR_SREV_9550(ah))
 658                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 659                         ar955x_1p0_modes_no_xpa_tx_gain_table);
 660         else if (AR_SREV_9531(ah)) {
 661                 if (AR_SREV_9531_20(ah))
 662                         INIT_INI_ARRAY(&ah->iniModesTxGain,
 663                                        qca953x_2p0_modes_no_xpa_tx_gain_table);
 664                 else if (AR_SREV_9531_11(ah))
 665                         INIT_INI_ARRAY(&ah->iniModesTxGain,
 666                                        qca953x_1p1_modes_no_xpa_tx_gain_table);
 667                 else
 668                         INIT_INI_ARRAY(&ah->iniModesTxGain,
 669                                        qca953x_1p0_modes_no_xpa_tx_gain_table);
 670         } else if (AR_SREV_9561(ah))
 671                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 672                                qca956x_1p0_modes_no_xpa_tx_gain_table);
 673         else if (AR_SREV_9462_21(ah))
 674                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 675                         ar9462_2p1_modes_high_ob_db_tx_gain);
 676         else if (AR_SREV_9462_20(ah))
 677                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 678                         ar9462_2p0_modes_high_ob_db_tx_gain);
 679         else if (AR_SREV_9565_11(ah))
 680                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 681                                ar9565_1p1_modes_high_ob_db_tx_gain_table);
 682         else if (AR_SREV_9565(ah))
 683                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 684                                ar9565_1p0_modes_high_ob_db_tx_gain_table);
 685         else
 686                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 687                         ar9300Modes_high_ob_db_tx_gain_table_2p2);
 688 }
 689 
 690 static void ar9003_tx_gain_table_mode2(struct ath_hw *ah)
 691 {
 692         if (AR_SREV_9330_12(ah))
 693                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 694                         ar9331_modes_low_ob_db_tx_gain_1p2);
 695         else if (AR_SREV_9330_11(ah))
 696                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 697                         ar9331_modes_low_ob_db_tx_gain_1p1);
 698         else if (AR_SREV_9340(ah))
 699                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 700                         ar9340Modes_low_ob_db_tx_gain_table_1p0);
 701         else if (AR_SREV_9531_11(ah))
 702                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 703                                qca953x_1p1_modes_no_xpa_low_power_tx_gain_table);
 704         else if (AR_SREV_9485_11_OR_LATER(ah))
 705                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 706                         ar9485Modes_low_ob_db_tx_gain_1_1);
 707         else if (AR_SREV_9580(ah))
 708                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 709                         ar9580_1p0_low_ob_db_tx_gain_table);
 710         else if (AR_SREV_9561(ah))
 711                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 712                                qca956x_1p0_modes_no_xpa_low_ob_db_tx_gain_table);
 713         else if (AR_SREV_9565_11(ah))
 714                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 715                                ar9565_1p1_modes_low_ob_db_tx_gain_table);
 716         else if (AR_SREV_9565(ah))
 717                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 718                                ar9565_1p0_modes_low_ob_db_tx_gain_table);
 719         else
 720                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 721                         ar9300Modes_low_ob_db_tx_gain_table_2p2);
 722 }
 723 
 724 static void ar9003_tx_gain_table_mode3(struct ath_hw *ah)
 725 {
 726         if (AR_SREV_9330_12(ah))
 727                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 728                         ar9331_modes_high_power_tx_gain_1p2);
 729         else if (AR_SREV_9330_11(ah))
 730                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 731                         ar9331_modes_high_power_tx_gain_1p1);
 732         else if (AR_SREV_9340(ah))
 733                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 734                         ar9340Modes_high_power_tx_gain_table_1p0);
 735         else if (AR_SREV_9485_11_OR_LATER(ah))
 736                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 737                         ar9485Modes_high_power_tx_gain_1_1);
 738         else if (AR_SREV_9580(ah))
 739                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 740                         ar9580_1p0_high_power_tx_gain_table);
 741         else if (AR_SREV_9565_11(ah))
 742                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 743                                ar9565_1p1_modes_high_power_tx_gain_table);
 744         else if (AR_SREV_9565(ah))
 745                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 746                                ar9565_1p0_modes_high_power_tx_gain_table);
 747         else {
 748                 if (ah->config.tx_gain_buffalo)
 749                         INIT_INI_ARRAY(&ah->iniModesTxGain,
 750                                        ar9300Modes_high_power_tx_gain_table_buffalo);
 751                 else
 752                         INIT_INI_ARRAY(&ah->iniModesTxGain,
 753                                        ar9300Modes_high_power_tx_gain_table_2p2);
 754         }
 755 }
 756 
 757 static void ar9003_tx_gain_table_mode4(struct ath_hw *ah)
 758 {
 759         if (AR_SREV_9340(ah))
 760                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 761                         ar9340Modes_mixed_ob_db_tx_gain_table_1p0);
 762         else if (AR_SREV_9580(ah))
 763                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 764                         ar9580_1p0_mixed_ob_db_tx_gain_table);
 765         else if (AR_SREV_9462_21(ah))
 766                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 767                        ar9462_2p1_modes_mix_ob_db_tx_gain);
 768         else if (AR_SREV_9462_20(ah))
 769                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 770                        ar9462_2p0_modes_mix_ob_db_tx_gain);
 771         else
 772                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 773                         ar9300Modes_mixed_ob_db_tx_gain_table_2p2);
 774 }
 775 
 776 static void ar9003_tx_gain_table_mode5(struct ath_hw *ah)
 777 {
 778         if (AR_SREV_9485_11_OR_LATER(ah))
 779                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 780                         ar9485Modes_green_ob_db_tx_gain_1_1);
 781         else if (AR_SREV_9580(ah))
 782                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 783                         ar9580_1p0_type5_tx_gain_table);
 784         else if (AR_SREV_9561(ah))
 785                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 786                                qca956x_1p0_modes_no_xpa_green_tx_gain_table);
 787         else if (AR_SREV_9300_22(ah))
 788                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 789                         ar9300Modes_type5_tx_gain_table_2p2);
 790 }
 791 
 792 static void ar9003_tx_gain_table_mode6(struct ath_hw *ah)
 793 {
 794         if (AR_SREV_9340(ah))
 795                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 796                         ar9340Modes_low_ob_db_and_spur_tx_gain_table_1p0);
 797         else if (AR_SREV_9485_11_OR_LATER(ah))
 798                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 799                         ar9485Modes_green_spur_ob_db_tx_gain_1_1);
 800         else if (AR_SREV_9580(ah))
 801                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 802                         ar9580_1p0_type6_tx_gain_table);
 803 }
 804 
 805 static void ar9003_tx_gain_table_mode7(struct ath_hw *ah)
 806 {
 807         if (AR_SREV_9340(ah))
 808                 INIT_INI_ARRAY(&ah->iniModesTxGain,
 809                                ar9340_cus227_tx_gain_table_1p0);
 810 }
 811 
 812 typedef void (*ath_txgain_tab)(struct ath_hw *ah);
 813 
 814 static void ar9003_tx_gain_table_apply(struct ath_hw *ah)
 815 {
 816         static const ath_txgain_tab modes[] = {
 817                 ar9003_tx_gain_table_mode0,
 818                 ar9003_tx_gain_table_mode1,
 819                 ar9003_tx_gain_table_mode2,
 820                 ar9003_tx_gain_table_mode3,
 821                 ar9003_tx_gain_table_mode4,
 822                 ar9003_tx_gain_table_mode5,
 823                 ar9003_tx_gain_table_mode6,
 824                 ar9003_tx_gain_table_mode7,
 825         };
 826         int idx = ar9003_hw_get_tx_gain_idx(ah);
 827 
 828         if (idx >= ARRAY_SIZE(modes))
 829                 idx = 0;
 830 
 831         modes[idx](ah);
 832 }
 833 
 834 static void ar9003_rx_gain_table_mode0(struct ath_hw *ah)
 835 {
 836         if (AR_SREV_9330_12(ah))
 837                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 838                                 ar9331_common_rx_gain_1p2);
 839         else if (AR_SREV_9330_11(ah))
 840                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 841                                 ar9331_common_rx_gain_1p1);
 842         else if (AR_SREV_9340(ah))
 843                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 844                                 ar9340Common_rx_gain_table_1p0);
 845         else if (AR_SREV_9485_11_OR_LATER(ah))
 846                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 847                                ar9485_common_rx_gain_1_1);
 848         else if (AR_SREV_9550(ah)) {
 849                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 850                                 ar955x_1p0_common_rx_gain_table);
 851                 INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
 852                                 ar955x_1p0_common_rx_gain_bounds);
 853         } else if (AR_SREV_9531(ah)) {
 854                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 855                                qca953x_1p0_common_rx_gain_table);
 856                 INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
 857                                qca953x_1p0_common_rx_gain_bounds);
 858         } else if (AR_SREV_9561(ah)) {
 859                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 860                                qca956x_1p0_common_rx_gain_table);
 861                 INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
 862                                qca956x_1p0_common_rx_gain_bounds);
 863                 INIT_INI_ARRAY(&ah->ini_modes_rxgain_xlna,
 864                                qca956x_1p0_xlna_only);
 865         } else if (AR_SREV_9580(ah))
 866                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 867                                 ar9580_1p0_rx_gain_table);
 868         else if (AR_SREV_9462_21(ah))
 869                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 870                                 ar9462_2p1_common_rx_gain);
 871         else if (AR_SREV_9462_20(ah))
 872                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 873                                 ar9462_2p0_common_rx_gain);
 874         else if (AR_SREV_9565_11(ah))
 875                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 876                                ar9565_1p1_Common_rx_gain_table);
 877         else if (AR_SREV_9565(ah))
 878                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 879                                ar9565_1p0_Common_rx_gain_table);
 880         else
 881                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 882                                 ar9300Common_rx_gain_table_2p2);
 883 }
 884 
 885 static void ar9003_rx_gain_table_mode1(struct ath_hw *ah)
 886 {
 887         if (AR_SREV_9330_12(ah))
 888                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 889                         ar9331_common_wo_xlna_rx_gain_1p2);
 890         else if (AR_SREV_9330_11(ah))
 891                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 892                         ar9331_common_wo_xlna_rx_gain_1p1);
 893         else if (AR_SREV_9340(ah))
 894                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 895                         ar9340Common_wo_xlna_rx_gain_table_1p0);
 896         else if (AR_SREV_9485_11_OR_LATER(ah))
 897                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 898                         ar9485Common_wo_xlna_rx_gain_1_1);
 899         else if (AR_SREV_9462_21(ah))
 900                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 901                         ar9462_2p1_common_wo_xlna_rx_gain);
 902         else if (AR_SREV_9462_20(ah))
 903                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 904                         ar9462_2p0_common_wo_xlna_rx_gain);
 905         else if (AR_SREV_9550(ah)) {
 906                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 907                         ar955x_1p0_common_wo_xlna_rx_gain_table);
 908                 INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
 909                         ar955x_1p0_common_wo_xlna_rx_gain_bounds);
 910         } else if (AR_SREV_9531_10(ah) || AR_SREV_9531_11(ah)) {
 911                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 912                                qca953x_1p0_common_wo_xlna_rx_gain_table);
 913                 INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
 914                                qca953x_1p0_common_wo_xlna_rx_gain_bounds);
 915         } else if (AR_SREV_9531_20(ah)) {
 916                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 917                                qca953x_2p0_common_wo_xlna_rx_gain_table);
 918                 INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
 919                                qca953x_2p0_common_wo_xlna_rx_gain_bounds);
 920         } else if (AR_SREV_9561(ah)) {
 921                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 922                                qca956x_1p0_common_wo_xlna_rx_gain_table);
 923                 INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
 924                                qca956x_1p0_common_wo_xlna_rx_gain_bounds);
 925         } else if (AR_SREV_9580(ah))
 926                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 927                         ar9580_1p0_wo_xlna_rx_gain_table);
 928         else if (AR_SREV_9565_11(ah))
 929                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 930                                ar9565_1p1_common_wo_xlna_rx_gain_table);
 931         else if (AR_SREV_9565(ah))
 932                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 933                                ar9565_1p0_common_wo_xlna_rx_gain_table);
 934         else
 935                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 936                         ar9300Common_wo_xlna_rx_gain_table_2p2);
 937 }
 938 
 939 static void ar9003_rx_gain_table_mode2(struct ath_hw *ah)
 940 {
 941         if (AR_SREV_9462_21(ah)) {
 942                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 943                                ar9462_2p1_common_mixed_rx_gain);
 944                 INIT_INI_ARRAY(&ah->ini_modes_rxgain_bb_core,
 945                                ar9462_2p1_baseband_core_mix_rxgain);
 946                 INIT_INI_ARRAY(&ah->ini_modes_rxgain_bb_postamble,
 947                                ar9462_2p1_baseband_postamble_mix_rxgain);
 948                 INIT_INI_ARRAY(&ah->ini_modes_rxgain_xlna,
 949                                ar9462_2p1_baseband_postamble_5g_xlna);
 950         } else if (AR_SREV_9462_20(ah)) {
 951                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 952                                ar9462_2p0_common_mixed_rx_gain);
 953                 INIT_INI_ARRAY(&ah->ini_modes_rxgain_bb_core,
 954                                ar9462_2p0_baseband_core_mix_rxgain);
 955                 INIT_INI_ARRAY(&ah->ini_modes_rxgain_bb_postamble,
 956                                ar9462_2p0_baseband_postamble_mix_rxgain);
 957                 INIT_INI_ARRAY(&ah->ini_modes_rxgain_xlna,
 958                                ar9462_2p0_baseband_postamble_5g_xlna);
 959         }
 960 }
 961 
 962 static void ar9003_rx_gain_table_mode3(struct ath_hw *ah)
 963 {
 964         if (AR_SREV_9462_21(ah)) {
 965                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 966                                ar9462_2p1_common_5g_xlna_only_rxgain);
 967                 INIT_INI_ARRAY(&ah->ini_modes_rxgain_xlna,
 968                                ar9462_2p1_baseband_postamble_5g_xlna);
 969         } else if (AR_SREV_9462_20(ah)) {
 970                 INIT_INI_ARRAY(&ah->iniModesRxGain,
 971                                ar9462_2p0_common_5g_xlna_only_rxgain);
 972                 INIT_INI_ARRAY(&ah->ini_modes_rxgain_xlna,
 973                                ar9462_2p0_baseband_postamble_5g_xlna);
 974         }
 975 }
 976 
 977 static void ar9003_rx_gain_table_apply(struct ath_hw *ah)
 978 {
 979         switch (ar9003_hw_get_rx_gain_idx(ah)) {
 980         case 0:
 981         default:
 982                 ar9003_rx_gain_table_mode0(ah);
 983                 break;
 984         case 1:
 985                 ar9003_rx_gain_table_mode1(ah);
 986                 break;
 987         case 2:
 988                 ar9003_rx_gain_table_mode2(ah);
 989                 break;
 990         case 3:
 991                 ar9003_rx_gain_table_mode3(ah);
 992                 break;
 993         }
 994 }
 995 
 996 /* set gain table pointers according to values read from the eeprom */
 997 static void ar9003_hw_init_mode_gain_regs(struct ath_hw *ah)
 998 {
 999         ar9003_tx_gain_table_apply(ah);
1000         ar9003_rx_gain_table_apply(ah);
1001 }
1002 
1003 /*
1004  * Helper for ASPM support.
1005  *
1006  * Disable PLL when in L0s as well as receiver clock when in L1.
1007  * This power saving option must be enabled through the SerDes.
1008  *
1009  * Programming the SerDes must go through the same 288 bit serial shift
1010  * register as the other analog registers.  Hence the 9 writes.
1011  */
1012 static void ar9003_hw_configpcipowersave(struct ath_hw *ah,
1013                                          bool power_off)
1014 {
1015         unsigned int i;
1016         struct ar5416IniArray *array;
1017 
1018         /*
1019          * Increase L1 Entry Latency. Some WB222 boards don't have
1020          * this change in eeprom/OTP.
1021          *
1022          */
1023         if (AR_SREV_9462(ah)) {
1024                 u32 val = ah->config.aspm_l1_fix;
1025                 if ((val & 0xff000000) == 0x17000000) {
1026                         val &= 0x00ffffff;
1027                         val |= 0x27000000;
1028                         REG_WRITE(ah, 0x570c, val);
1029                 }
1030         }
1031 
1032         /* Nothing to do on restore for 11N */
1033         if (!power_off /* !restore */) {
1034                 /* set bit 19 to allow forcing of pcie core into L1 state */
1035                 REG_SET_BIT(ah, AR_PCIE_PM_CTRL, AR_PCIE_PM_CTRL_ENA);
1036                 REG_WRITE(ah, AR_WA, ah->WARegVal);
1037         }
1038 
1039         /*
1040          * Configire PCIE after Ini init. SERDES values now come from ini file
1041          * This enables PCIe low power mode.
1042          */
1043         array = power_off ? &ah->iniPcieSerdes :
1044                 &ah->iniPcieSerdesLowPower;
1045 
1046         for (i = 0; i < array->ia_rows; i++) {
1047                 REG_WRITE(ah,
1048                           INI_RA(array, i, 0),
1049                           INI_RA(array, i, 1));
1050         }
1051 }
1052 
1053 static void ar9003_hw_init_hang_checks(struct ath_hw *ah)
1054 {
1055         /*
1056          * All chips support detection of BB/MAC hangs.
1057          */
1058         ah->config.hw_hang_checks |= HW_BB_WATCHDOG;
1059         ah->config.hw_hang_checks |= HW_MAC_HANG;
1060 
1061         /*
1062          * This is not required for AR9580 1.0
1063          */
1064         if (AR_SREV_9300_22(ah))
1065                 ah->config.hw_hang_checks |= HW_PHYRESTART_CLC_WAR;
1066 
1067         if (AR_SREV_9330(ah))
1068                 ah->bb_watchdog_timeout_ms = 85;
1069         else
1070                 ah->bb_watchdog_timeout_ms = 25;
1071 }
1072 
1073 /*
1074  * MAC HW hang check
1075  * =================
1076  *
1077  * Signature: dcu_chain_state is 0x6 and dcu_complete_state is 0x1.
1078  *
1079  * The state of each DCU chain (mapped to TX queues) is available from these
1080  * DMA debug registers:
1081  *
1082  * Chain 0 state : Bits 4:0   of AR_DMADBG_4
1083  * Chain 1 state : Bits 9:5   of AR_DMADBG_4
1084  * Chain 2 state : Bits 14:10 of AR_DMADBG_4
1085  * Chain 3 state : Bits 19:15 of AR_DMADBG_4
1086  * Chain 4 state : Bits 24:20 of AR_DMADBG_4
1087  * Chain 5 state : Bits 29:25 of AR_DMADBG_4
1088  * Chain 6 state : Bits 4:0   of AR_DMADBG_5
1089  * Chain 7 state : Bits 9:5   of AR_DMADBG_5
1090  * Chain 8 state : Bits 14:10 of AR_DMADBG_5
1091  * Chain 9 state : Bits 19:15 of AR_DMADBG_5
1092  *
1093  * The DCU chain state "0x6" means "WAIT_FRDONE" - wait for TX frame to be done.
1094  */
1095 
1096 #define NUM_STATUS_READS 50
1097 
1098 static bool ath9k_hw_verify_hang(struct ath_hw *ah, unsigned int queue)
1099 {
1100         u32 dma_dbg_chain, dma_dbg_complete;
1101         u8 dcu_chain_state, dcu_complete_state;
1102         int i;
1103 
1104         for (i = 0; i < NUM_STATUS_READS; i++) {
1105                 if (queue < 6)
1106                         dma_dbg_chain = REG_READ(ah, AR_DMADBG_4);
1107                 else
1108                         dma_dbg_chain = REG_READ(ah, AR_DMADBG_5);
1109 
1110                 dma_dbg_complete = REG_READ(ah, AR_DMADBG_6);
1111 
1112                 dcu_chain_state = (dma_dbg_chain >> (5 * queue)) & 0x1f;
1113                 dcu_complete_state = dma_dbg_complete & 0x3;
1114 
1115                 if ((dcu_chain_state != 0x6) || (dcu_complete_state != 0x1))
1116                         return false;
1117         }
1118 
1119         ath_dbg(ath9k_hw_common(ah), RESET,
1120                 "MAC Hang signature found for queue: %d\n", queue);
1121 
1122         return true;
1123 }
1124 
1125 static bool ar9003_hw_detect_mac_hang(struct ath_hw *ah)
1126 {
1127         u32 dma_dbg_4, dma_dbg_5, dma_dbg_6, chk_dbg;
1128         u8 dcu_chain_state, dcu_complete_state;
1129         bool dcu_wait_frdone = false;
1130         unsigned long chk_dcu = 0;
1131         unsigned int i = 0;
1132 
1133         dma_dbg_4 = REG_READ(ah, AR_DMADBG_4);
1134         dma_dbg_5 = REG_READ(ah, AR_DMADBG_5);
1135         dma_dbg_6 = REG_READ(ah, AR_DMADBG_6);
1136 
1137         dcu_complete_state = dma_dbg_6 & 0x3;
1138         if (dcu_complete_state != 0x1)
1139                 goto exit;
1140 
1141         for (i = 0; i < ATH9K_NUM_TX_QUEUES; i++) {
1142                 if (i < 6)
1143                         chk_dbg = dma_dbg_4;
1144                 else
1145                         chk_dbg = dma_dbg_5;
1146 
1147                 dcu_chain_state = (chk_dbg >> (5 * i)) & 0x1f;
1148                 if (dcu_chain_state == 0x6) {
1149                         dcu_wait_frdone = true;
1150                         chk_dcu |= BIT(i);
1151                 }
1152         }
1153 
1154         if ((dcu_complete_state == 0x1) && dcu_wait_frdone) {
1155                 for_each_set_bit(i, &chk_dcu, ATH9K_NUM_TX_QUEUES) {
1156                         if (ath9k_hw_verify_hang(ah, i))
1157                                 return true;
1158                 }
1159         }
1160 exit:
1161         return false;
1162 }
1163 
1164 /* Sets up the AR9003 hardware familiy callbacks */
1165 void ar9003_hw_attach_ops(struct ath_hw *ah)
1166 {
1167         struct ath_hw_private_ops *priv_ops = ath9k_hw_private_ops(ah);
1168         struct ath_hw_ops *ops = ath9k_hw_ops(ah);
1169 
1170         ar9003_hw_init_mode_regs(ah);
1171 
1172         if (AR_SREV_9003_PCOEM(ah)) {
1173                 WARN_ON(!ah->iniPcieSerdes.ia_array);
1174                 WARN_ON(!ah->iniPcieSerdesLowPower.ia_array);
1175         }
1176 
1177         priv_ops->init_mode_gain_regs = ar9003_hw_init_mode_gain_regs;
1178         priv_ops->init_hang_checks = ar9003_hw_init_hang_checks;
1179         priv_ops->detect_mac_hang = ar9003_hw_detect_mac_hang;
1180 
1181         ops->config_pci_powersave = ar9003_hw_configpcipowersave;
1182 
1183         ar9003_hw_attach_phy_ops(ah);
1184         ar9003_hw_attach_calib_ops(ah);
1185         ar9003_hw_attach_mac_ops(ah);
1186         ar9003_hw_attach_aic_ops(ah);
1187 }

/* [<][>][^][v][top][bottom][index][help] */