blob: 06ad2172030e7d63f55390b191bb2e7f9adb1c78 [file] [log] [blame]
Luis R. Rodriguezb3950e62010-04-15 17:39:03 -04001/*
Sujith Manoharan5b681382011-05-17 13:36:18 +05302 * Copyright (c) 2008-2011 Atheros Communications Inc.
Luis R. Rodriguezb3950e62010-04-15 17:39:03 -04003 *
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"
Luis R. Rodriguezb622a722010-04-15 17:39:28 -040018#include "ar9003_mac.h"
Luis R. Rodriguez72846352010-05-12 21:15:05 -040019#include "ar9003_2p2_initvals.h"
Sujith Manoharan0f978bf2013-12-06 16:28:45 +053020#include "ar9003_buffalo_initvals.h"
Vasanthakumar Thiagarajanc88457e2010-12-06 04:27:37 -080021#include "ar9485_initvals.h"
Vasanthakumar Thiagarajand89baac2011-04-19 19:29:04 +053022#include "ar9340_initvals.h"
Gabor Juhos172805a2011-06-21 11:23:26 +020023#include "ar9330_1p1_initvals.h"
24#include "ar9330_1p2_initvals.h"
Gabor Juhosa0fbb9b2012-07-03 19:13:22 +020025#include "ar955x_1p0_initvals.h"
Luis R. Rodriguez5a63ef02011-08-24 15:36:08 -070026#include "ar9580_1p0_initvals.h"
Rajkumar Manoharan76db2f82011-10-13 11:00:43 +053027#include "ar9462_2p0_initvals.h"
Sujith Manoharand567e4e2013-06-24 18:18:45 +053028#include "ar9462_2p1_initvals.h"
Sujith Manoharanaaa53ee2012-09-10 09:19:54 +053029#include "ar9565_1p0_initvals.h"
Sujith Manoharan3777f7d2013-11-19 12:11:13 +053030#include "ar9565_1p1_initvals.h"
Sujith Manoharanb6b57302013-12-31 08:12:01 +053031#include "ar953x_initvals.h"
Luis R. Rodriguezb3950e62010-04-15 17:39:03 -040032
33/* General hardware code for the AR9003 hadware family */
34
Luis R. Rodriguez886b42b2010-10-14 11:44:27 -070035/*
36 * The AR9003 family uses a new INI format (pre, core, post
37 * arrays per subsystem). This provides support for the
38 * AR9003 2.2 chipsets.
39 */
40static void ar9003_hw_init_mode_regs(struct ath_hw *ah)
Luis R. Rodriguez72846352010-05-12 21:15:05 -040041{
Gabor Juhos172805a2011-06-21 11:23:26 +020042 if (AR_SREV_9330_11(ah)) {
43 /* mac */
Gabor Juhos172805a2011-06-21 11:23:26 +020044 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
Felix Fietkaua3645172012-07-15 19:53:33 +020045 ar9331_1p1_mac_core);
Gabor Juhos172805a2011-06-21 11:23:26 +020046 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +020047 ar9331_1p1_mac_postamble);
Gabor Juhos172805a2011-06-21 11:23:26 +020048
49 /* bb */
Gabor Juhos172805a2011-06-21 11:23:26 +020050 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
Felix Fietkaua3645172012-07-15 19:53:33 +020051 ar9331_1p1_baseband_core);
Gabor Juhos172805a2011-06-21 11:23:26 +020052 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +020053 ar9331_1p1_baseband_postamble);
Gabor Juhos172805a2011-06-21 11:23:26 +020054
55 /* radio */
Gabor Juhos172805a2011-06-21 11:23:26 +020056 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
Felix Fietkaua3645172012-07-15 19:53:33 +020057 ar9331_1p1_radio_core);
Gabor Juhos172805a2011-06-21 11:23:26 +020058
59 /* soc */
60 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
Felix Fietkaua3645172012-07-15 19:53:33 +020061 ar9331_1p1_soc_preamble);
Gabor Juhos172805a2011-06-21 11:23:26 +020062 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +020063 ar9331_1p1_soc_postamble);
Gabor Juhos172805a2011-06-21 11:23:26 +020064
65 /* rx/tx gain */
66 INIT_INI_ARRAY(&ah->iniModesRxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +020067 ar9331_common_rx_gain_1p1);
Gabor Juhos172805a2011-06-21 11:23:26 +020068 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +020069 ar9331_modes_lowest_ob_db_tx_gain_1p1);
Gabor Juhos172805a2011-06-21 11:23:26 +020070
Sujith Manoharan57527f82012-11-13 11:33:53 +053071 /* Japan 2484 Mhz CCK */
72 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
73 ar9331_1p1_baseband_core_txfir_coeff_japan_2484);
74
Gabor Juhos172805a2011-06-21 11:23:26 +020075 /* additional clock settings */
76 if (ah->is_clk_25mhz)
Felix Fietkauc7d36f92012-03-14 16:40:31 +010077 INIT_INI_ARRAY(&ah->iniAdditional,
Felix Fietkaua3645172012-07-15 19:53:33 +020078 ar9331_1p1_xtal_25M);
Gabor Juhos172805a2011-06-21 11:23:26 +020079 else
Felix Fietkauc7d36f92012-03-14 16:40:31 +010080 INIT_INI_ARRAY(&ah->iniAdditional,
Felix Fietkaua3645172012-07-15 19:53:33 +020081 ar9331_1p1_xtal_40M);
Gabor Juhos172805a2011-06-21 11:23:26 +020082 } else if (AR_SREV_9330_12(ah)) {
83 /* mac */
Gabor Juhos172805a2011-06-21 11:23:26 +020084 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
Felix Fietkaua3645172012-07-15 19:53:33 +020085 ar9331_1p2_mac_core);
Gabor Juhos172805a2011-06-21 11:23:26 +020086 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +020087 ar9331_1p2_mac_postamble);
Gabor Juhos172805a2011-06-21 11:23:26 +020088
89 /* bb */
Gabor Juhos172805a2011-06-21 11:23:26 +020090 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
Felix Fietkaua3645172012-07-15 19:53:33 +020091 ar9331_1p2_baseband_core);
Gabor Juhos172805a2011-06-21 11:23:26 +020092 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +020093 ar9331_1p2_baseband_postamble);
Gabor Juhos172805a2011-06-21 11:23:26 +020094
95 /* radio */
Gabor Juhos172805a2011-06-21 11:23:26 +020096 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
Felix Fietkaua3645172012-07-15 19:53:33 +020097 ar9331_1p2_radio_core);
Gabor Juhos172805a2011-06-21 11:23:26 +020098
99 /* soc */
100 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200101 ar9331_1p2_soc_preamble);
Gabor Juhos172805a2011-06-21 11:23:26 +0200102 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200103 ar9331_1p2_soc_postamble);
Gabor Juhos172805a2011-06-21 11:23:26 +0200104
105 /* rx/tx gain */
106 INIT_INI_ARRAY(&ah->iniModesRxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200107 ar9331_common_rx_gain_1p2);
Gabor Juhos172805a2011-06-21 11:23:26 +0200108 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200109 ar9331_modes_lowest_ob_db_tx_gain_1p2);
Gabor Juhos172805a2011-06-21 11:23:26 +0200110
Sujith Manoharan57527f82012-11-13 11:33:53 +0530111 /* Japan 2484 Mhz CCK */
112 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
113 ar9331_1p2_baseband_core_txfir_coeff_japan_2484);
114
Gabor Juhos172805a2011-06-21 11:23:26 +0200115 /* additional clock settings */
116 if (ah->is_clk_25mhz)
Felix Fietkauc7d36f92012-03-14 16:40:31 +0100117 INIT_INI_ARRAY(&ah->iniAdditional,
Felix Fietkaua3645172012-07-15 19:53:33 +0200118 ar9331_1p2_xtal_25M);
Gabor Juhos172805a2011-06-21 11:23:26 +0200119 else
Felix Fietkauc7d36f92012-03-14 16:40:31 +0100120 INIT_INI_ARRAY(&ah->iniAdditional,
Felix Fietkaua3645172012-07-15 19:53:33 +0200121 ar9331_1p2_xtal_40M);
Gabor Juhos172805a2011-06-21 11:23:26 +0200122 } else if (AR_SREV_9340(ah)) {
Vasanthakumar Thiagarajand89baac2011-04-19 19:29:04 +0530123 /* mac */
Vasanthakumar Thiagarajand89baac2011-04-19 19:29:04 +0530124 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200125 ar9340_1p0_mac_core);
Vasanthakumar Thiagarajand89baac2011-04-19 19:29:04 +0530126 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200127 ar9340_1p0_mac_postamble);
Vasanthakumar Thiagarajand89baac2011-04-19 19:29:04 +0530128
129 /* bb */
Vasanthakumar Thiagarajand89baac2011-04-19 19:29:04 +0530130 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200131 ar9340_1p0_baseband_core);
Vasanthakumar Thiagarajand89baac2011-04-19 19:29:04 +0530132 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200133 ar9340_1p0_baseband_postamble);
Vasanthakumar Thiagarajand89baac2011-04-19 19:29:04 +0530134
135 /* radio */
Vasanthakumar Thiagarajand89baac2011-04-19 19:29:04 +0530136 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200137 ar9340_1p0_radio_core);
Vasanthakumar Thiagarajand89baac2011-04-19 19:29:04 +0530138 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200139 ar9340_1p0_radio_postamble);
Vasanthakumar Thiagarajand89baac2011-04-19 19:29:04 +0530140
141 /* soc */
142 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200143 ar9340_1p0_soc_preamble);
Vasanthakumar Thiagarajand89baac2011-04-19 19:29:04 +0530144 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200145 ar9340_1p0_soc_postamble);
Vasanthakumar Thiagarajand89baac2011-04-19 19:29:04 +0530146
147 /* rx/tx gain */
148 INIT_INI_ARRAY(&ah->iniModesRxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200149 ar9340Common_wo_xlna_rx_gain_table_1p0);
Vasanthakumar Thiagarajand89baac2011-04-19 19:29:04 +0530150 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200151 ar9340Modes_high_ob_db_tx_gain_table_1p0);
Vasanthakumar Thiagarajand89baac2011-04-19 19:29:04 +0530152
Felix Fietkauc7d36f92012-03-14 16:40:31 +0100153 INIT_INI_ARRAY(&ah->iniModesFastClock,
Sujith Manoharan2c8672c2013-12-02 09:56:31 +0530154 ar9340Modes_fast_clock_1p0);
155 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
156 ar9340_1p0_baseband_core_txfir_coeff_japan_2484);
Sujith Manoharan4a878b92013-12-06 16:28:40 +0530157 INIT_INI_ARRAY(&ah->ini_dfs,
158 ar9340_1p0_baseband_postamble_dfs_channel);
Vasanthakumar Thiagarajand89baac2011-04-19 19:29:04 +0530159
Felix Fietkauc7d36f92012-03-14 16:40:31 +0100160 if (!ah->is_clk_25mhz)
161 INIT_INI_ARRAY(&ah->iniAdditional,
Felix Fietkaua3645172012-07-15 19:53:33 +0200162 ar9340_1p0_radio_core_40M);
Sujith Manoharanfb5a2dc2013-08-19 11:03:43 +0530163 } else if (AR_SREV_9485_11_OR_LATER(ah)) {
Vivek Natarajan1a63e2c2011-02-18 16:49:47 +0530164 /* mac */
Vivek Natarajan1a63e2c2011-02-18 16:49:47 +0530165 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200166 ar9485_1_1_mac_core);
Vivek Natarajan1a63e2c2011-02-18 16:49:47 +0530167 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200168 ar9485_1_1_mac_postamble);
Vivek Natarajan1a63e2c2011-02-18 16:49:47 +0530169
170 /* bb */
Felix Fietkaua3645172012-07-15 19:53:33 +0200171 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_PRE], ar9485_1_1);
Vivek Natarajan1a63e2c2011-02-18 16:49:47 +0530172 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200173 ar9485_1_1_baseband_core);
Vivek Natarajan1a63e2c2011-02-18 16:49:47 +0530174 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200175 ar9485_1_1_baseband_postamble);
Vivek Natarajan1a63e2c2011-02-18 16:49:47 +0530176
177 /* radio */
Vivek Natarajan1a63e2c2011-02-18 16:49:47 +0530178 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200179 ar9485_1_1_radio_core);
Vivek Natarajan1a63e2c2011-02-18 16:49:47 +0530180 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200181 ar9485_1_1_radio_postamble);
Vivek Natarajan1a63e2c2011-02-18 16:49:47 +0530182
183 /* soc */
184 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200185 ar9485_1_1_soc_preamble);
Vivek Natarajan1a63e2c2011-02-18 16:49:47 +0530186
187 /* rx/tx gain */
188 INIT_INI_ARRAY(&ah->iniModesRxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200189 ar9485Common_wo_xlna_rx_gain_1_1);
Vivek Natarajan1a63e2c2011-02-18 16:49:47 +0530190 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200191 ar9485_modes_lowest_ob_db_tx_gain_1_1);
Vivek Natarajan1a63e2c2011-02-18 16:49:47 +0530192
Sujith Manoharan57527f82012-11-13 11:33:53 +0530193 /* Japan 2484 Mhz CCK */
194 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
195 ar9485_1_1_baseband_core_txfir_coeff_japan_2484);
196
Sujith Manoharan2d22c7d2013-11-08 11:45:25 +0530197 if (ah->config.no_pll_pwrsave) {
198 INIT_INI_ARRAY(&ah->iniPcieSerdes,
199 ar9485_1_1_pcie_phy_clkreq_disable_L1);
200 INIT_INI_ARRAY(&ah->iniPcieSerdesLowPower,
201 ar9485_1_1_pcie_phy_clkreq_disable_L1);
202 } else {
203 INIT_INI_ARRAY(&ah->iniPcieSerdes,
204 ar9485_1_1_pll_on_cdr_on_clkreq_disable_L1);
205 INIT_INI_ARRAY(&ah->iniPcieSerdesLowPower,
206 ar9485_1_1_pll_on_cdr_on_clkreq_disable_L1);
207 }
Sujith Manoharand567e4e2013-06-24 18:18:45 +0530208 } else if (AR_SREV_9462_21(ah)) {
209 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
210 ar9462_2p1_mac_core);
211 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
212 ar9462_2p1_mac_postamble);
213 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
214 ar9462_2p1_baseband_core);
215 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
216 ar9462_2p1_baseband_postamble);
217 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
218 ar9462_2p1_radio_core);
219 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
220 ar9462_2p1_radio_postamble);
221 INIT_INI_ARRAY(&ah->ini_radio_post_sys2ant,
222 ar9462_2p1_radio_postamble_sys2ant);
223 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
224 ar9462_2p1_soc_preamble);
225 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
226 ar9462_2p1_soc_postamble);
227 INIT_INI_ARRAY(&ah->iniModesRxGain,
228 ar9462_2p1_common_rx_gain);
229 INIT_INI_ARRAY(&ah->iniModesFastClock,
230 ar9462_2p1_modes_fast_clock);
231 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
232 ar9462_2p1_baseband_core_txfir_coeff_japan_2484);
Sujith Manoharanf51ecd72013-10-29 11:35:31 +0530233 INIT_INI_ARRAY(&ah->iniPcieSerdes,
234 ar9462_2p1_pciephy_clkreq_disable_L1);
235 INIT_INI_ARRAY(&ah->iniPcieSerdesLowPower,
236 ar9462_2p1_pciephy_clkreq_disable_L1);
Rajkumar Manoharan423e38e2011-10-13 11:00:44 +0530237 } else if (AR_SREV_9462_20(ah)) {
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530238
Felix Fietkaua3645172012-07-15 19:53:33 +0200239 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE], ar9462_2p0_mac_core);
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530240 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200241 ar9462_2p0_mac_postamble);
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530242
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530243 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200244 ar9462_2p0_baseband_core);
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530245 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200246 ar9462_2p0_baseband_postamble);
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530247
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530248 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200249 ar9462_2p0_radio_core);
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530250 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200251 ar9462_2p0_radio_postamble);
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530252 INIT_INI_ARRAY(&ah->ini_radio_post_sys2ant,
Felix Fietkaua3645172012-07-15 19:53:33 +0200253 ar9462_2p0_radio_postamble_sys2ant);
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530254
255 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200256 ar9462_2p0_soc_preamble);
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530257 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200258 ar9462_2p0_soc_postamble);
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530259
260 INIT_INI_ARRAY(&ah->iniModesRxGain,
Sujith Manoharandbb3e2f2013-11-26 15:04:55 +0530261 ar9462_2p0_common_rx_gain);
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530262
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530263 /* Awake -> Sleep Setting */
264 INIT_INI_ARRAY(&ah->iniPcieSerdes,
Sujith Manoharandbb3e2f2013-11-26 15:04:55 +0530265 ar9462_2p0_pciephy_clkreq_disable_L1);
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530266 /* Sleep -> Awake Setting */
267 INIT_INI_ARRAY(&ah->iniPcieSerdesLowPower,
Sujith Manoharandbb3e2f2013-11-26 15:04:55 +0530268 ar9462_2p0_pciephy_clkreq_disable_L1);
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530269
270 /* Fast clock modal settings */
Felix Fietkauc7d36f92012-03-14 16:40:31 +0100271 INIT_INI_ARRAY(&ah->iniModesFastClock,
Sujith Manoharandbb3e2f2013-11-26 15:04:55 +0530272 ar9462_2p0_modes_fast_clock);
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530273
274 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
Sujith Manoharan57527f82012-11-13 11:33:53 +0530275 ar9462_2p0_baseband_core_txfir_coeff_japan_2484);
Gabor Juhos8bc45c62012-07-03 19:13:23 +0200276 } else if (AR_SREV_9550(ah)) {
277 /* mac */
Gabor Juhos8bc45c62012-07-03 19:13:23 +0200278 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200279 ar955x_1p0_mac_core);
Gabor Juhos8bc45c62012-07-03 19:13:23 +0200280 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200281 ar955x_1p0_mac_postamble);
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530282
Gabor Juhos8bc45c62012-07-03 19:13:23 +0200283 /* bb */
Gabor Juhos8bc45c62012-07-03 19:13:23 +0200284 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200285 ar955x_1p0_baseband_core);
Gabor Juhos8bc45c62012-07-03 19:13:23 +0200286 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200287 ar955x_1p0_baseband_postamble);
Gabor Juhos8bc45c62012-07-03 19:13:23 +0200288
289 /* radio */
Gabor Juhos8bc45c62012-07-03 19:13:23 +0200290 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200291 ar955x_1p0_radio_core);
Gabor Juhos8bc45c62012-07-03 19:13:23 +0200292 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200293 ar955x_1p0_radio_postamble);
Gabor Juhos8bc45c62012-07-03 19:13:23 +0200294
295 /* soc */
296 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200297 ar955x_1p0_soc_preamble);
Gabor Juhos8bc45c62012-07-03 19:13:23 +0200298 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200299 ar955x_1p0_soc_postamble);
Gabor Juhos8bc45c62012-07-03 19:13:23 +0200300
301 /* rx/tx gain */
302 INIT_INI_ARRAY(&ah->iniModesRxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200303 ar955x_1p0_common_wo_xlna_rx_gain_table);
Gabor Juhos8bc45c62012-07-03 19:13:23 +0200304 INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
Felix Fietkaua3645172012-07-15 19:53:33 +0200305 ar955x_1p0_common_wo_xlna_rx_gain_bounds);
Gabor Juhos8bc45c62012-07-03 19:13:23 +0200306 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200307 ar955x_1p0_modes_xpa_tx_gain_table);
Gabor Juhos8bc45c62012-07-03 19:13:23 +0200308
309 /* Fast clock modal settings */
310 INIT_INI_ARRAY(&ah->iniModesFastClock,
Felix Fietkaua3645172012-07-15 19:53:33 +0200311 ar955x_1p0_modes_fast_clock);
Sujith Manoharanb6b57302013-12-31 08:12:01 +0530312 } else if (AR_SREV_9531(ah)) {
313 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
314 qca953x_1p0_mac_core);
315 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
316 qca953x_1p0_mac_postamble);
Rajkumar Manoharanc01a7292014-06-24 22:27:37 +0530317 if (AR_SREV_9531_20(ah)) {
318 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
319 qca953x_2p0_baseband_core);
320 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
321 qca953x_2p0_baseband_postamble);
322 } else {
323 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
324 qca953x_1p0_baseband_core);
325 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
326 qca953x_1p0_baseband_postamble);
327 }
Sujith Manoharanb6b57302013-12-31 08:12:01 +0530328 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
329 qca953x_1p0_radio_core);
330 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
331 qca953x_1p0_radio_postamble);
332 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
333 qca953x_1p0_soc_preamble);
334 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
335 qca953x_1p0_soc_postamble);
Miaoqing Pan46270d02014-11-16 06:11:01 +0530336
337 if (AR_SREV_9531_20(ah)) {
338 INIT_INI_ARRAY(&ah->iniModesRxGain,
339 qca953x_2p0_common_wo_xlna_rx_gain_table);
340 INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
341 qca953x_2p0_common_wo_xlna_rx_gain_bounds);
342 } else {
343 INIT_INI_ARRAY(&ah->iniModesRxGain,
344 qca953x_1p0_common_wo_xlna_rx_gain_table);
345 INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
346 qca953x_1p0_common_wo_xlna_rx_gain_bounds);
347 }
348
349 if (AR_SREV_9531_20(ah))
350 INIT_INI_ARRAY(&ah->iniModesTxGain,
351 qca953x_2p0_modes_no_xpa_tx_gain_table);
352 else if (AR_SREV_9531_11(ah))
353 INIT_INI_ARRAY(&ah->iniModesTxGain,
354 qca953x_1p1_modes_no_xpa_tx_gain_table);
355 else
356 INIT_INI_ARRAY(&ah->iniModesTxGain,
357 qca953x_1p0_modes_no_xpa_tx_gain_table);
358
Sujith Manoharanb6b57302013-12-31 08:12:01 +0530359 INIT_INI_ARRAY(&ah->iniModesFastClock,
360 qca953x_1p0_modes_fast_clock);
Luis R. Rodriguez5a63ef02011-08-24 15:36:08 -0700361 } else if (AR_SREV_9580(ah)) {
362 /* mac */
Luis R. Rodriguez5a63ef02011-08-24 15:36:08 -0700363 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200364 ar9580_1p0_mac_core);
Luis R. Rodriguez5a63ef02011-08-24 15:36:08 -0700365 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200366 ar9580_1p0_mac_postamble);
Luis R. Rodriguez5a63ef02011-08-24 15:36:08 -0700367
368 /* bb */
Luis R. Rodriguez5a63ef02011-08-24 15:36:08 -0700369 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200370 ar9580_1p0_baseband_core);
Luis R. Rodriguez5a63ef02011-08-24 15:36:08 -0700371 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200372 ar9580_1p0_baseband_postamble);
Luis R. Rodriguez5a63ef02011-08-24 15:36:08 -0700373
374 /* radio */
Luis R. Rodriguez5a63ef02011-08-24 15:36:08 -0700375 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200376 ar9580_1p0_radio_core);
Luis R. Rodriguez5a63ef02011-08-24 15:36:08 -0700377 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200378 ar9580_1p0_radio_postamble);
Luis R. Rodriguez5a63ef02011-08-24 15:36:08 -0700379
380 /* soc */
381 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200382 ar9580_1p0_soc_preamble);
Luis R. Rodriguez5a63ef02011-08-24 15:36:08 -0700383 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200384 ar9580_1p0_soc_postamble);
Luis R. Rodriguez5a63ef02011-08-24 15:36:08 -0700385
386 /* rx/tx gain */
387 INIT_INI_ARRAY(&ah->iniModesRxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200388 ar9580_1p0_rx_gain_table);
Luis R. Rodriguez5a63ef02011-08-24 15:36:08 -0700389 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200390 ar9580_1p0_low_ob_db_tx_gain_table);
Luis R. Rodriguez5a63ef02011-08-24 15:36:08 -0700391
Felix Fietkauc7d36f92012-03-14 16:40:31 +0100392 INIT_INI_ARRAY(&ah->iniModesFastClock,
Sujith Manoharan2c8672c2013-12-02 09:56:31 +0530393 ar9580_1p0_modes_fast_clock);
394 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
395 ar9580_1p0_baseband_core_txfir_coeff_japan_2484);
Sujith Manoharan4a878b92013-12-06 16:28:40 +0530396 INIT_INI_ARRAY(&ah->ini_dfs,
397 ar9580_1p0_baseband_postamble_dfs_channel);
Sujith Manoharan3777f7d2013-11-19 12:11:13 +0530398 } else if (AR_SREV_9565_11_OR_LATER(ah)) {
399 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
400 ar9565_1p1_mac_core);
401 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
402 ar9565_1p1_mac_postamble);
403
404 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
405 ar9565_1p1_baseband_core);
406 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
407 ar9565_1p1_baseband_postamble);
408
409 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
410 ar9565_1p1_radio_core);
411 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
412 ar9565_1p1_radio_postamble);
413
414 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
415 ar9565_1p1_soc_preamble);
416 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
417 ar9565_1p1_soc_postamble);
418
419 INIT_INI_ARRAY(&ah->iniModesRxGain,
420 ar9565_1p1_Common_rx_gain_table);
421 INIT_INI_ARRAY(&ah->iniModesTxGain,
422 ar9565_1p1_Modes_lowest_ob_db_tx_gain_table);
423
424 INIT_INI_ARRAY(&ah->iniPcieSerdes,
425 ar9565_1p1_pciephy_clkreq_disable_L1);
426 INIT_INI_ARRAY(&ah->iniPcieSerdesLowPower,
427 ar9565_1p1_pciephy_clkreq_disable_L1);
428
429 INIT_INI_ARRAY(&ah->iniModesFastClock,
430 ar9565_1p1_modes_fast_clock);
431 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
432 ar9565_1p1_baseband_core_txfir_coeff_japan_2484);
Sujith Manoharanaaa53ee2012-09-10 09:19:54 +0530433 } else if (AR_SREV_9565(ah)) {
434 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
435 ar9565_1p0_mac_core);
436 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
437 ar9565_1p0_mac_postamble);
438
439 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
440 ar9565_1p0_baseband_core);
441 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
442 ar9565_1p0_baseband_postamble);
443
444 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
445 ar9565_1p0_radio_core);
446 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
447 ar9565_1p0_radio_postamble);
448
449 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
450 ar9565_1p0_soc_preamble);
451 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
452 ar9565_1p0_soc_postamble);
453
454 INIT_INI_ARRAY(&ah->iniModesRxGain,
455 ar9565_1p0_Common_rx_gain_table);
456 INIT_INI_ARRAY(&ah->iniModesTxGain,
457 ar9565_1p0_Modes_lowest_ob_db_tx_gain_table);
458
459 INIT_INI_ARRAY(&ah->iniPcieSerdes,
Rajkumar Manoharan84464842012-10-25 17:16:51 +0530460 ar9565_1p0_pciephy_clkreq_disable_L1);
Sujith Manoharanaaa53ee2012-09-10 09:19:54 +0530461 INIT_INI_ARRAY(&ah->iniPcieSerdesLowPower,
Rajkumar Manoharan84464842012-10-25 17:16:51 +0530462 ar9565_1p0_pciephy_clkreq_disable_L1);
Sujith Manoharanaaa53ee2012-09-10 09:19:54 +0530463
464 INIT_INI_ARRAY(&ah->iniModesFastClock,
465 ar9565_1p0_modes_fast_clock);
Sujith Manoharan6d5228f2013-09-03 10:28:56 +0530466 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
467 ar9565_1p0_baseband_core_txfir_coeff_japan_2484);
Vasanthakumar Thiagarajanc88457e2010-12-06 04:27:37 -0800468 } else {
469 /* mac */
Vasanthakumar Thiagarajanc88457e2010-12-06 04:27:37 -0800470 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200471 ar9300_2p2_mac_core);
Vasanthakumar Thiagarajanc88457e2010-12-06 04:27:37 -0800472 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200473 ar9300_2p2_mac_postamble);
Luis R. Rodriguez72846352010-05-12 21:15:05 -0400474
Vasanthakumar Thiagarajanc88457e2010-12-06 04:27:37 -0800475 /* bb */
Vasanthakumar Thiagarajanc88457e2010-12-06 04:27:37 -0800476 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200477 ar9300_2p2_baseband_core);
Vasanthakumar Thiagarajanc88457e2010-12-06 04:27:37 -0800478 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200479 ar9300_2p2_baseband_postamble);
Vasanthakumar Thiagarajanc88457e2010-12-06 04:27:37 -0800480
481 /* radio */
Vasanthakumar Thiagarajanc88457e2010-12-06 04:27:37 -0800482 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200483 ar9300_2p2_radio_core);
Vasanthakumar Thiagarajanc88457e2010-12-06 04:27:37 -0800484 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200485 ar9300_2p2_radio_postamble);
Vasanthakumar Thiagarajanc88457e2010-12-06 04:27:37 -0800486
487 /* soc */
488 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
Felix Fietkaua3645172012-07-15 19:53:33 +0200489 ar9300_2p2_soc_preamble);
Vasanthakumar Thiagarajanc88457e2010-12-06 04:27:37 -0800490 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
Felix Fietkaua3645172012-07-15 19:53:33 +0200491 ar9300_2p2_soc_postamble);
Vasanthakumar Thiagarajanc88457e2010-12-06 04:27:37 -0800492
493 /* rx/tx gain */
494 INIT_INI_ARRAY(&ah->iniModesRxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200495 ar9300Common_rx_gain_table_2p2);
Vasanthakumar Thiagarajanc88457e2010-12-06 04:27:37 -0800496 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200497 ar9300Modes_lowest_ob_db_tx_gain_table_2p2);
Vasanthakumar Thiagarajanc88457e2010-12-06 04:27:37 -0800498
499 /* Load PCIE SERDES settings from INI */
500
501 /* Awake Setting */
502
503 INIT_INI_ARRAY(&ah->iniPcieSerdes,
Felix Fietkaua3645172012-07-15 19:53:33 +0200504 ar9300PciePhy_pll_on_clkreq_disable_L1_2p2);
Vasanthakumar Thiagarajanc88457e2010-12-06 04:27:37 -0800505
506 /* Sleep Setting */
507
508 INIT_INI_ARRAY(&ah->iniPcieSerdesLowPower,
Felix Fietkaua3645172012-07-15 19:53:33 +0200509 ar9300PciePhy_pll_on_clkreq_disable_L1_2p2);
Vasanthakumar Thiagarajanc88457e2010-12-06 04:27:37 -0800510
511 /* Fast clock modal settings */
Felix Fietkauc7d36f92012-03-14 16:40:31 +0100512 INIT_INI_ARRAY(&ah->iniModesFastClock,
Sujith Manoharan2c8672c2013-12-02 09:56:31 +0530513 ar9300Modes_fast_clock_2p2);
514 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
515 ar9300_2p2_baseband_core_txfir_coeff_japan_2484);
Sujith Manoharan4a878b92013-12-06 16:28:40 +0530516 INIT_INI_ARRAY(&ah->ini_dfs,
517 ar9300_2p2_baseband_postamble_dfs_channel);
Vasanthakumar Thiagarajanc88457e2010-12-06 04:27:37 -0800518 }
Luis R. Rodriguez72846352010-05-12 21:15:05 -0400519}
520
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530521static void ar9003_tx_gain_table_mode0(struct ath_hw *ah)
522{
523 if (AR_SREV_9330_12(ah))
524 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200525 ar9331_modes_lowest_ob_db_tx_gain_1p2);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530526 else if (AR_SREV_9330_11(ah))
527 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200528 ar9331_modes_lowest_ob_db_tx_gain_1p1);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530529 else if (AR_SREV_9340(ah))
530 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200531 ar9340Modes_lowest_ob_db_tx_gain_table_1p0);
Sujith Manoharanfb5a2dc2013-08-19 11:03:43 +0530532 else if (AR_SREV_9485_11_OR_LATER(ah))
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530533 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200534 ar9485_modes_lowest_ob_db_tx_gain_1_1);
Gabor Juhos8bc45c62012-07-03 19:13:23 +0200535 else if (AR_SREV_9550(ah))
536 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200537 ar955x_1p0_modes_xpa_tx_gain_table);
Miaoqing Pan46270d02014-11-16 06:11:01 +0530538 else if (AR_SREV_9531_10(ah))
Sujith Manoharanb6b57302013-12-31 08:12:01 +0530539 INIT_INI_ARRAY(&ah->iniModesTxGain,
Miaoqing Pan46270d02014-11-16 06:11:01 +0530540 qca953x_1p0_modes_xpa_tx_gain_table);
541 else if (AR_SREV_9531_11(ah))
542 INIT_INI_ARRAY(&ah->iniModesTxGain,
543 qca953x_1p1_modes_xpa_tx_gain_table);
544 else if (AR_SREV_9531_20(ah))
545 INIT_INI_ARRAY(&ah->iniModesTxGain,
546 qca953x_2p0_modes_xpa_tx_gain_table);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530547 else if (AR_SREV_9580(ah))
548 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200549 ar9580_1p0_lowest_ob_db_tx_gain_table);
Sujith Manoharand567e4e2013-06-24 18:18:45 +0530550 else if (AR_SREV_9462_21(ah))
551 INIT_INI_ARRAY(&ah->iniModesTxGain,
552 ar9462_2p1_modes_low_ob_db_tx_gain);
Rajkumar Manoharan423e38e2011-10-13 11:00:44 +0530553 else if (AR_SREV_9462_20(ah))
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530554 INIT_INI_ARRAY(&ah->iniModesTxGain,
Sujith Manoharandbb3e2f2013-11-26 15:04:55 +0530555 ar9462_2p0_modes_low_ob_db_tx_gain);
Sujith Manoharan3777f7d2013-11-19 12:11:13 +0530556 else if (AR_SREV_9565_11(ah))
557 INIT_INI_ARRAY(&ah->iniModesTxGain,
558 ar9565_1p1_modes_low_ob_db_tx_gain_table);
Sujith Manoharanaaa53ee2012-09-10 09:19:54 +0530559 else if (AR_SREV_9565(ah))
560 INIT_INI_ARRAY(&ah->iniModesTxGain,
561 ar9565_1p0_modes_low_ob_db_tx_gain_table);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530562 else
563 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200564 ar9300Modes_lowest_ob_db_tx_gain_table_2p2);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530565}
566
567static void ar9003_tx_gain_table_mode1(struct ath_hw *ah)
568{
569 if (AR_SREV_9330_12(ah))
570 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200571 ar9331_modes_high_ob_db_tx_gain_1p2);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530572 else if (AR_SREV_9330_11(ah))
573 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200574 ar9331_modes_high_ob_db_tx_gain_1p1);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530575 else if (AR_SREV_9340(ah))
576 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200577 ar9340Modes_high_ob_db_tx_gain_table_1p0);
Sujith Manoharanfb5a2dc2013-08-19 11:03:43 +0530578 else if (AR_SREV_9485_11_OR_LATER(ah))
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530579 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200580 ar9485Modes_high_ob_db_tx_gain_1_1);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530581 else if (AR_SREV_9580(ah))
582 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200583 ar9580_1p0_high_ob_db_tx_gain_table);
Gabor Juhos8bc45c62012-07-03 19:13:23 +0200584 else if (AR_SREV_9550(ah))
585 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200586 ar955x_1p0_modes_no_xpa_tx_gain_table);
Sujith Manoharanb6b57302013-12-31 08:12:01 +0530587 else if (AR_SREV_9531(ah)) {
Miaoqing Pan46270d02014-11-16 06:11:01 +0530588 if (AR_SREV_9531_20(ah))
589 INIT_INI_ARRAY(&ah->iniModesTxGain,
590 qca953x_2p0_modes_no_xpa_tx_gain_table);
591 else if (AR_SREV_9531_11(ah))
Sujith Manoharanb6b57302013-12-31 08:12:01 +0530592 INIT_INI_ARRAY(&ah->iniModesTxGain,
593 qca953x_1p1_modes_no_xpa_tx_gain_table);
594 else
595 INIT_INI_ARRAY(&ah->iniModesTxGain,
596 qca953x_1p0_modes_no_xpa_tx_gain_table);
597 } else if (AR_SREV_9462_21(ah))
Sujith Manoharand567e4e2013-06-24 18:18:45 +0530598 INIT_INI_ARRAY(&ah->iniModesTxGain,
599 ar9462_2p1_modes_high_ob_db_tx_gain);
Rajkumar Manoharan423e38e2011-10-13 11:00:44 +0530600 else if (AR_SREV_9462_20(ah))
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530601 INIT_INI_ARRAY(&ah->iniModesTxGain,
Sujith Manoharandbb3e2f2013-11-26 15:04:55 +0530602 ar9462_2p0_modes_high_ob_db_tx_gain);
Sujith Manoharan3777f7d2013-11-19 12:11:13 +0530603 else if (AR_SREV_9565_11(ah))
604 INIT_INI_ARRAY(&ah->iniModesTxGain,
605 ar9565_1p1_modes_high_ob_db_tx_gain_table);
Sujith Manoharanaaa53ee2012-09-10 09:19:54 +0530606 else if (AR_SREV_9565(ah))
607 INIT_INI_ARRAY(&ah->iniModesTxGain,
608 ar9565_1p0_modes_high_ob_db_tx_gain_table);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530609 else
610 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200611 ar9300Modes_high_ob_db_tx_gain_table_2p2);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530612}
613
614static void ar9003_tx_gain_table_mode2(struct ath_hw *ah)
615{
616 if (AR_SREV_9330_12(ah))
617 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200618 ar9331_modes_low_ob_db_tx_gain_1p2);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530619 else if (AR_SREV_9330_11(ah))
620 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200621 ar9331_modes_low_ob_db_tx_gain_1p1);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530622 else if (AR_SREV_9340(ah))
623 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200624 ar9340Modes_low_ob_db_tx_gain_table_1p0);
Sujith Manoharanfb5a2dc2013-08-19 11:03:43 +0530625 else if (AR_SREV_9485_11_OR_LATER(ah))
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530626 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200627 ar9485Modes_low_ob_db_tx_gain_1_1);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530628 else if (AR_SREV_9580(ah))
629 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200630 ar9580_1p0_low_ob_db_tx_gain_table);
Sujith Manoharan3777f7d2013-11-19 12:11:13 +0530631 else if (AR_SREV_9565_11(ah))
632 INIT_INI_ARRAY(&ah->iniModesTxGain,
633 ar9565_1p1_modes_low_ob_db_tx_gain_table);
Sujith Manoharanaaa53ee2012-09-10 09:19:54 +0530634 else if (AR_SREV_9565(ah))
635 INIT_INI_ARRAY(&ah->iniModesTxGain,
636 ar9565_1p0_modes_low_ob_db_tx_gain_table);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530637 else
638 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200639 ar9300Modes_low_ob_db_tx_gain_table_2p2);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530640}
641
642static void ar9003_tx_gain_table_mode3(struct ath_hw *ah)
643{
644 if (AR_SREV_9330_12(ah))
645 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200646 ar9331_modes_high_power_tx_gain_1p2);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530647 else if (AR_SREV_9330_11(ah))
648 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200649 ar9331_modes_high_power_tx_gain_1p1);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530650 else if (AR_SREV_9340(ah))
651 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200652 ar9340Modes_high_power_tx_gain_table_1p0);
Sujith Manoharanfb5a2dc2013-08-19 11:03:43 +0530653 else if (AR_SREV_9485_11_OR_LATER(ah))
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530654 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200655 ar9485Modes_high_power_tx_gain_1_1);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530656 else if (AR_SREV_9580(ah))
657 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200658 ar9580_1p0_high_power_tx_gain_table);
Sujith Manoharan3777f7d2013-11-19 12:11:13 +0530659 else if (AR_SREV_9565_11(ah))
660 INIT_INI_ARRAY(&ah->iniModesTxGain,
661 ar9565_1p1_modes_high_power_tx_gain_table);
Sujith Manoharanaaa53ee2012-09-10 09:19:54 +0530662 else if (AR_SREV_9565(ah))
663 INIT_INI_ARRAY(&ah->iniModesTxGain,
664 ar9565_1p0_modes_high_power_tx_gain_table);
Sujith Manoharan0f978bf2013-12-06 16:28:45 +0530665 else {
666 if (ah->config.tx_gain_buffalo)
667 INIT_INI_ARRAY(&ah->iniModesTxGain,
668 ar9300Modes_high_power_tx_gain_table_buffalo);
669 else
670 INIT_INI_ARRAY(&ah->iniModesTxGain,
671 ar9300Modes_high_power_tx_gain_table_2p2);
672 }
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530673}
674
Felix Fietkaub05a0112012-07-15 19:53:32 +0200675static void ar9003_tx_gain_table_mode4(struct ath_hw *ah)
676{
677 if (AR_SREV_9340(ah))
678 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200679 ar9340Modes_mixed_ob_db_tx_gain_table_1p0);
Felix Fietkaub05a0112012-07-15 19:53:32 +0200680 else if (AR_SREV_9580(ah))
681 INIT_INI_ARRAY(&ah->iniModesTxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200682 ar9580_1p0_mixed_ob_db_tx_gain_table);
Sujith Manoharand567e4e2013-06-24 18:18:45 +0530683 else if (AR_SREV_9462_21(ah))
684 INIT_INI_ARRAY(&ah->iniModesTxGain,
685 ar9462_2p1_modes_mix_ob_db_tx_gain);
Sujith Manoharan9a54c172013-06-25 12:29:23 +0530686 else if (AR_SREV_9462_20(ah))
687 INIT_INI_ARRAY(&ah->iniModesTxGain,
Sujith Manoharandbb3e2f2013-11-26 15:04:55 +0530688 ar9462_2p0_modes_mix_ob_db_tx_gain);
Felix Fietkaueab6d792013-01-10 19:41:52 +0100689 else
690 INIT_INI_ARRAY(&ah->iniModesTxGain,
691 ar9300Modes_mixed_ob_db_tx_gain_table_2p2);
Felix Fietkaub05a0112012-07-15 19:53:32 +0200692}
693
Felix Fietkaueab6d792013-01-10 19:41:52 +0100694static void ar9003_tx_gain_table_mode5(struct ath_hw *ah)
695{
Sujith Manoharanfb5a2dc2013-08-19 11:03:43 +0530696 if (AR_SREV_9485_11_OR_LATER(ah))
Felix Fietkaueab6d792013-01-10 19:41:52 +0100697 INIT_INI_ARRAY(&ah->iniModesTxGain,
698 ar9485Modes_green_ob_db_tx_gain_1_1);
Felix Fietkaueab6d792013-01-10 19:41:52 +0100699 else if (AR_SREV_9580(ah))
700 INIT_INI_ARRAY(&ah->iniModesTxGain,
701 ar9580_1p0_type5_tx_gain_table);
702 else if (AR_SREV_9300_22(ah))
703 INIT_INI_ARRAY(&ah->iniModesTxGain,
704 ar9300Modes_type5_tx_gain_table_2p2);
705}
706
707static void ar9003_tx_gain_table_mode6(struct ath_hw *ah)
708{
709 if (AR_SREV_9340(ah))
710 INIT_INI_ARRAY(&ah->iniModesTxGain,
711 ar9340Modes_low_ob_db_and_spur_tx_gain_table_1p0);
Sujith Manoharanfb5a2dc2013-08-19 11:03:43 +0530712 else if (AR_SREV_9485_11_OR_LATER(ah))
Felix Fietkaueab6d792013-01-10 19:41:52 +0100713 INIT_INI_ARRAY(&ah->iniModesTxGain,
714 ar9485Modes_green_spur_ob_db_tx_gain_1_1);
715 else if (AR_SREV_9580(ah))
716 INIT_INI_ARRAY(&ah->iniModesTxGain,
717 ar9580_1p0_type6_tx_gain_table);
718}
719
Sujith Manoharan8fd007a2013-11-05 05:54:59 +0530720static void ar9003_tx_gain_table_mode7(struct ath_hw *ah)
721{
722 if (AR_SREV_9340(ah))
723 INIT_INI_ARRAY(&ah->iniModesTxGain,
724 ar9340_cus227_tx_gain_table_1p0);
725}
726
Felix Fietkaueab6d792013-01-10 19:41:52 +0100727typedef void (*ath_txgain_tab)(struct ath_hw *ah);
728
Luis R. Rodriguezc14a85d2010-04-15 17:39:21 -0400729static void ar9003_tx_gain_table_apply(struct ath_hw *ah)
730{
Felix Fietkaueab6d792013-01-10 19:41:52 +0100731 static const ath_txgain_tab modes[] = {
732 ar9003_tx_gain_table_mode0,
733 ar9003_tx_gain_table_mode1,
734 ar9003_tx_gain_table_mode2,
735 ar9003_tx_gain_table_mode3,
736 ar9003_tx_gain_table_mode4,
737 ar9003_tx_gain_table_mode5,
738 ar9003_tx_gain_table_mode6,
Sujith Manoharan8fd007a2013-11-05 05:54:59 +0530739 ar9003_tx_gain_table_mode7,
Felix Fietkaueab6d792013-01-10 19:41:52 +0100740 };
741 int idx = ar9003_hw_get_tx_gain_idx(ah);
742
743 if (idx >= ARRAY_SIZE(modes))
744 idx = 0;
745
746 modes[idx](ah);
Luis R. Rodriguezc14a85d2010-04-15 17:39:21 -0400747}
748
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530749static void ar9003_rx_gain_table_mode0(struct ath_hw *ah)
750{
751 if (AR_SREV_9330_12(ah))
752 INIT_INI_ARRAY(&ah->iniModesRxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200753 ar9331_common_rx_gain_1p2);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530754 else if (AR_SREV_9330_11(ah))
755 INIT_INI_ARRAY(&ah->iniModesRxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200756 ar9331_common_rx_gain_1p1);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530757 else if (AR_SREV_9340(ah))
758 INIT_INI_ARRAY(&ah->iniModesRxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200759 ar9340Common_rx_gain_table_1p0);
Sujith Manoharanfb5a2dc2013-08-19 11:03:43 +0530760 else if (AR_SREV_9485_11_OR_LATER(ah))
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530761 INIT_INI_ARRAY(&ah->iniModesRxGain,
Sujith Manoharana796a1d2012-12-26 12:27:39 +0530762 ar9485_common_rx_gain_1_1);
Gabor Juhos8bc45c62012-07-03 19:13:23 +0200763 else if (AR_SREV_9550(ah)) {
764 INIT_INI_ARRAY(&ah->iniModesRxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200765 ar955x_1p0_common_rx_gain_table);
Gabor Juhos8bc45c62012-07-03 19:13:23 +0200766 INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
Felix Fietkaua3645172012-07-15 19:53:33 +0200767 ar955x_1p0_common_rx_gain_bounds);
Sujith Manoharanb6b57302013-12-31 08:12:01 +0530768 } else if (AR_SREV_9531(ah)) {
769 INIT_INI_ARRAY(&ah->iniModesRxGain,
770 qca953x_1p0_common_rx_gain_table);
771 INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
772 qca953x_1p0_common_rx_gain_bounds);
Gabor Juhos8bc45c62012-07-03 19:13:23 +0200773 } else if (AR_SREV_9580(ah))
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530774 INIT_INI_ARRAY(&ah->iniModesRxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200775 ar9580_1p0_rx_gain_table);
Sujith Manoharand567e4e2013-06-24 18:18:45 +0530776 else if (AR_SREV_9462_21(ah))
777 INIT_INI_ARRAY(&ah->iniModesRxGain,
778 ar9462_2p1_common_rx_gain);
Rajkumar Manoharan423e38e2011-10-13 11:00:44 +0530779 else if (AR_SREV_9462_20(ah))
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530780 INIT_INI_ARRAY(&ah->iniModesRxGain,
Sujith Manoharandbb3e2f2013-11-26 15:04:55 +0530781 ar9462_2p0_common_rx_gain);
Sujith Manoharan3777f7d2013-11-19 12:11:13 +0530782 else if (AR_SREV_9565_11(ah))
783 INIT_INI_ARRAY(&ah->iniModesRxGain,
784 ar9565_1p1_Common_rx_gain_table);
Sujith Manoharan6ac21502013-09-02 13:59:02 +0530785 else if (AR_SREV_9565(ah))
786 INIT_INI_ARRAY(&ah->iniModesRxGain,
787 ar9565_1p0_Common_rx_gain_table);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530788 else
789 INIT_INI_ARRAY(&ah->iniModesRxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200790 ar9300Common_rx_gain_table_2p2);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530791}
792
793static void ar9003_rx_gain_table_mode1(struct ath_hw *ah)
794{
795 if (AR_SREV_9330_12(ah))
796 INIT_INI_ARRAY(&ah->iniModesRxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200797 ar9331_common_wo_xlna_rx_gain_1p2);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530798 else if (AR_SREV_9330_11(ah))
799 INIT_INI_ARRAY(&ah->iniModesRxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200800 ar9331_common_wo_xlna_rx_gain_1p1);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530801 else if (AR_SREV_9340(ah))
802 INIT_INI_ARRAY(&ah->iniModesRxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200803 ar9340Common_wo_xlna_rx_gain_table_1p0);
Sujith Manoharanfb5a2dc2013-08-19 11:03:43 +0530804 else if (AR_SREV_9485_11_OR_LATER(ah))
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530805 INIT_INI_ARRAY(&ah->iniModesRxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200806 ar9485Common_wo_xlna_rx_gain_1_1);
Sujith Manoharand567e4e2013-06-24 18:18:45 +0530807 else if (AR_SREV_9462_21(ah))
808 INIT_INI_ARRAY(&ah->iniModesRxGain,
809 ar9462_2p1_common_wo_xlna_rx_gain);
Rajkumar Manoharan423e38e2011-10-13 11:00:44 +0530810 else if (AR_SREV_9462_20(ah))
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530811 INIT_INI_ARRAY(&ah->iniModesRxGain,
Sujith Manoharandbb3e2f2013-11-26 15:04:55 +0530812 ar9462_2p0_common_wo_xlna_rx_gain);
Gabor Juhos8bc45c62012-07-03 19:13:23 +0200813 else if (AR_SREV_9550(ah)) {
814 INIT_INI_ARRAY(&ah->iniModesRxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200815 ar955x_1p0_common_wo_xlna_rx_gain_table);
Gabor Juhos8bc45c62012-07-03 19:13:23 +0200816 INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
Felix Fietkaua3645172012-07-15 19:53:33 +0200817 ar955x_1p0_common_wo_xlna_rx_gain_bounds);
Miaoqing Pan46270d02014-11-16 06:11:01 +0530818 } else if (AR_SREV_9531_10(ah) || AR_SREV_9531_11(ah)) {
Sujith Manoharanb6b57302013-12-31 08:12:01 +0530819 INIT_INI_ARRAY(&ah->iniModesRxGain,
820 qca953x_1p0_common_wo_xlna_rx_gain_table);
821 INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
822 qca953x_1p0_common_wo_xlna_rx_gain_bounds);
Miaoqing Pan46270d02014-11-16 06:11:01 +0530823 } else if (AR_SREV_9531_20(ah)) {
824 INIT_INI_ARRAY(&ah->iniModesRxGain,
825 qca953x_2p0_common_wo_xlna_rx_gain_table);
826 INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
827 qca953x_2p0_common_wo_xlna_rx_gain_bounds);
Gabor Juhos8bc45c62012-07-03 19:13:23 +0200828 } else if (AR_SREV_9580(ah))
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530829 INIT_INI_ARRAY(&ah->iniModesRxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200830 ar9580_1p0_wo_xlna_rx_gain_table);
Sujith Manoharan3777f7d2013-11-19 12:11:13 +0530831 else if (AR_SREV_9565_11(ah))
832 INIT_INI_ARRAY(&ah->iniModesRxGain,
833 ar9565_1p1_common_wo_xlna_rx_gain_table);
Sujith Manoharanaaa53ee2012-09-10 09:19:54 +0530834 else if (AR_SREV_9565(ah))
835 INIT_INI_ARRAY(&ah->iniModesRxGain,
836 ar9565_1p0_common_wo_xlna_rx_gain_table);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530837 else
838 INIT_INI_ARRAY(&ah->iniModesRxGain,
Felix Fietkaua3645172012-07-15 19:53:33 +0200839 ar9300Common_wo_xlna_rx_gain_table_2p2);
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530840}
841
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530842static void ar9003_rx_gain_table_mode2(struct ath_hw *ah)
843{
Sujith Manoharand567e4e2013-06-24 18:18:45 +0530844 if (AR_SREV_9462_21(ah)) {
845 INIT_INI_ARRAY(&ah->iniModesRxGain,
846 ar9462_2p1_common_mixed_rx_gain);
847 INIT_INI_ARRAY(&ah->ini_modes_rxgain_bb_core,
848 ar9462_2p1_baseband_core_mix_rxgain);
849 INIT_INI_ARRAY(&ah->ini_modes_rxgain_bb_postamble,
850 ar9462_2p1_baseband_postamble_mix_rxgain);
851 INIT_INI_ARRAY(&ah->ini_modes_rxgain_5g_xlna,
852 ar9462_2p1_baseband_postamble_5g_xlna);
853 } else if (AR_SREV_9462_20(ah)) {
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530854 INIT_INI_ARRAY(&ah->iniModesRxGain,
Sujith Manoharandbb3e2f2013-11-26 15:04:55 +0530855 ar9462_2p0_common_mixed_rx_gain);
Sujith Manoharanc177fab2013-06-18 15:42:38 +0530856 INIT_INI_ARRAY(&ah->ini_modes_rxgain_bb_core,
857 ar9462_2p0_baseband_core_mix_rxgain);
858 INIT_INI_ARRAY(&ah->ini_modes_rxgain_bb_postamble,
859 ar9462_2p0_baseband_postamble_mix_rxgain);
Sujith Manoharan51dbd0a2013-06-18 10:13:42 +0530860 INIT_INI_ARRAY(&ah->ini_modes_rxgain_5g_xlna,
861 ar9462_2p0_baseband_postamble_5g_xlna);
862 }
863}
864
865static void ar9003_rx_gain_table_mode3(struct ath_hw *ah)
866{
Sujith Manoharand567e4e2013-06-24 18:18:45 +0530867 if (AR_SREV_9462_21(ah)) {
868 INIT_INI_ARRAY(&ah->iniModesRxGain,
Sujith Manoharandbb3e2f2013-11-26 15:04:55 +0530869 ar9462_2p1_common_5g_xlna_only_rxgain);
Sujith Manoharand567e4e2013-06-24 18:18:45 +0530870 INIT_INI_ARRAY(&ah->ini_modes_rxgain_5g_xlna,
871 ar9462_2p1_baseband_postamble_5g_xlna);
872 } else if (AR_SREV_9462_20(ah)) {
Sujith Manoharan51dbd0a2013-06-18 10:13:42 +0530873 INIT_INI_ARRAY(&ah->iniModesRxGain,
Sujith Manoharandbb3e2f2013-11-26 15:04:55 +0530874 ar9462_2p0_common_5g_xlna_only_rxgain);
Sujith Manoharan51dbd0a2013-06-18 10:13:42 +0530875 INIT_INI_ARRAY(&ah->ini_modes_rxgain_5g_xlna,
876 ar9462_2p0_baseband_postamble_5g_xlna);
877 }
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530878}
879
Luis R. Rodriguezc14a85d2010-04-15 17:39:21 -0400880static void ar9003_rx_gain_table_apply(struct ath_hw *ah)
881{
882 switch (ar9003_hw_get_rx_gain_idx(ah)) {
883 case 0:
884 default:
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530885 ar9003_rx_gain_table_mode0(ah);
Luis R. Rodriguezc14a85d2010-04-15 17:39:21 -0400886 break;
887 case 1:
Senthil Balasubramanian4d0707e2011-09-13 22:38:17 +0530888 ar9003_rx_gain_table_mode1(ah);
Luis R. Rodriguezc14a85d2010-04-15 17:39:21 -0400889 break;
Senthil Balasubramanian2577c6e2011-09-13 22:38:18 +0530890 case 2:
891 ar9003_rx_gain_table_mode2(ah);
892 break;
Sujith Manoharan51dbd0a2013-06-18 10:13:42 +0530893 case 3:
894 ar9003_rx_gain_table_mode3(ah);
895 break;
Luis R. Rodriguezc14a85d2010-04-15 17:39:21 -0400896 }
897}
898
899/* set gain table pointers according to values read from the eeprom */
900static void ar9003_hw_init_mode_gain_regs(struct ath_hw *ah)
901{
902 ar9003_tx_gain_table_apply(ah);
903 ar9003_rx_gain_table_apply(ah);
904}
905
Luis R. Rodriguezb3950e62010-04-15 17:39:03 -0400906/*
907 * Helper for ASPM support.
908 *
909 * Disable PLL when in L0s as well as receiver clock when in L1.
910 * This power saving option must be enabled through the SerDes.
911 *
912 * Programming the SerDes must go through the same 288 bit serial shift
913 * register as the other analog registers. Hence the 9 writes.
914 */
915static void ar9003_hw_configpcipowersave(struct ath_hw *ah,
Stanislaw Gruszka84c87dc2011-08-05 13:10:32 +0200916 bool power_off)
Luis R. Rodriguezb3950e62010-04-15 17:39:03 -0400917{
Sujith Manoharanc6fc7e62013-10-29 11:52:06 +0530918 unsigned int i;
919 struct ar5416IniArray *array;
920
Sujith Manoharanb380a43b2013-08-25 14:43:09 +0530921 /*
922 * Increase L1 Entry Latency. Some WB222 boards don't have
923 * this change in eeprom/OTP.
924 *
925 */
926 if (AR_SREV_9462(ah)) {
927 u32 val = ah->config.aspm_l1_fix;
928 if ((val & 0xff000000) == 0x17000000) {
929 val &= 0x00ffffff;
930 val |= 0x27000000;
931 REG_WRITE(ah, 0x570c, val);
932 }
933 }
934
Luis R. Rodriguezb3950e62010-04-15 17:39:03 -0400935 /* Nothing to do on restore for 11N */
Stanislaw Gruszka84c87dc2011-08-05 13:10:32 +0200936 if (!power_off /* !restore */) {
Luis R. Rodriguezb3950e62010-04-15 17:39:03 -0400937 /* set bit 19 to allow forcing of pcie core into L1 state */
938 REG_SET_BIT(ah, AR_PCIE_PM_CTRL, AR_PCIE_PM_CTRL_ENA);
Sujith Manoharand1ae25a2013-08-25 16:30:40 +0530939 REG_WRITE(ah, AR_WA, ah->WARegVal);
Luis R. Rodriguezb3950e62010-04-15 17:39:03 -0400940 }
Luis R. Rodriguez653fe372010-06-21 18:38:48 -0400941
942 /*
943 * Configire PCIE after Ini init. SERDES values now come from ini file
944 * This enables PCIe low power mode.
945 */
Sujith Manoharanc6fc7e62013-10-29 11:52:06 +0530946 array = power_off ? &ah->iniPcieSerdes :
947 &ah->iniPcieSerdesLowPower;
Luis R. Rodriguez653fe372010-06-21 18:38:48 -0400948
Sujith Manoharanc6fc7e62013-10-29 11:52:06 +0530949 for (i = 0; i < array->ia_rows; i++) {
950 REG_WRITE(ah,
951 INI_RA(array, i, 0),
952 INI_RA(array, i, 1));
Luis R. Rodriguez653fe372010-06-21 18:38:48 -0400953 }
Luis R. Rodriguezb3950e62010-04-15 17:39:03 -0400954}
955
Sujith Manoharan45987022013-12-24 10:44:18 +0530956static void ar9003_hw_init_hang_checks(struct ath_hw *ah)
957{
958 /*
959 * All chips support detection of BB/MAC hangs.
960 */
961 ah->config.hw_hang_checks |= HW_BB_WATCHDOG;
962 ah->config.hw_hang_checks |= HW_MAC_HANG;
963
964 /*
965 * This is not required for AR9580 1.0
966 */
967 if (AR_SREV_9300_22(ah))
968 ah->config.hw_hang_checks |= HW_PHYRESTART_CLC_WAR;
969
970 if (AR_SREV_9330(ah))
971 ah->bb_watchdog_timeout_ms = 85;
972 else
973 ah->bb_watchdog_timeout_ms = 25;
974}
975
Sujith Manoharan222e0482013-12-24 10:44:20 +0530976/*
977 * MAC HW hang check
978 * =================
979 *
980 * Signature: dcu_chain_state is 0x6 and dcu_complete_state is 0x1.
981 *
982 * The state of each DCU chain (mapped to TX queues) is available from these
983 * DMA debug registers:
984 *
985 * Chain 0 state : Bits 4:0 of AR_DMADBG_4
986 * Chain 1 state : Bits 9:5 of AR_DMADBG_4
987 * Chain 2 state : Bits 14:10 of AR_DMADBG_4
988 * Chain 3 state : Bits 19:15 of AR_DMADBG_4
989 * Chain 4 state : Bits 24:20 of AR_DMADBG_4
990 * Chain 5 state : Bits 29:25 of AR_DMADBG_4
991 * Chain 6 state : Bits 4:0 of AR_DMADBG_5
992 * Chain 7 state : Bits 9:5 of AR_DMADBG_5
993 * Chain 8 state : Bits 14:10 of AR_DMADBG_5
994 * Chain 9 state : Bits 19:15 of AR_DMADBG_5
995 *
996 * The DCU chain state "0x6" means "WAIT_FRDONE" - wait for TX frame to be done.
997 */
998
999#define NUM_STATUS_READS 50
1000
1001static bool ath9k_hw_verify_hang(struct ath_hw *ah, unsigned int queue)
Sujith Manoharan990de2b2013-12-24 10:44:19 +05301002{
Sujith Manoharan222e0482013-12-24 10:44:20 +05301003 u32 dma_dbg_chain, dma_dbg_complete;
1004 u8 dcu_chain_state, dcu_complete_state;
1005 int i;
Sujith Manoharan990de2b2013-12-24 10:44:19 +05301006
1007 for (i = 0; i < NUM_STATUS_READS; i++) {
Sujith Manoharan222e0482013-12-24 10:44:20 +05301008 if (queue < 6)
1009 dma_dbg_chain = REG_READ(ah, AR_DMADBG_4);
1010 else
1011 dma_dbg_chain = REG_READ(ah, AR_DMADBG_5);
Sujith Manoharan990de2b2013-12-24 10:44:19 +05301012
Sujith Manoharan222e0482013-12-24 10:44:20 +05301013 dma_dbg_complete = REG_READ(ah, AR_DMADBG_6);
1014
1015 dcu_chain_state = (dma_dbg_chain >> (5 * queue)) & 0x1f;
1016 dcu_complete_state = dma_dbg_complete & 0x3;
1017
1018 if ((dcu_chain_state != 0x6) || (dcu_complete_state != 0x1))
Sujith Manoharan990de2b2013-12-24 10:44:19 +05301019 return false;
1020 }
1021
Sujith Manoharan222e0482013-12-24 10:44:20 +05301022 ath_dbg(ath9k_hw_common(ah), RESET,
1023 "MAC Hang signature found for queue: %d\n", queue);
Sujith Manoharan990de2b2013-12-24 10:44:19 +05301024
1025 return true;
1026}
1027
Sujith Manoharan222e0482013-12-24 10:44:20 +05301028static bool ar9003_hw_detect_mac_hang(struct ath_hw *ah)
1029{
1030 u32 dma_dbg_4, dma_dbg_5, dma_dbg_6, chk_dbg;
1031 u8 dcu_chain_state, dcu_complete_state;
1032 bool dcu_wait_frdone = false;
1033 unsigned long chk_dcu = 0;
1034 unsigned int i = 0;
1035
1036 dma_dbg_4 = REG_READ(ah, AR_DMADBG_4);
1037 dma_dbg_5 = REG_READ(ah, AR_DMADBG_5);
1038 dma_dbg_6 = REG_READ(ah, AR_DMADBG_6);
1039
1040 dcu_complete_state = dma_dbg_6 & 0x3;
1041 if (dcu_complete_state != 0x1)
1042 goto exit;
1043
1044 for (i = 0; i < ATH9K_NUM_TX_QUEUES; i++) {
1045 if (i < 6)
1046 chk_dbg = dma_dbg_4;
1047 else
1048 chk_dbg = dma_dbg_5;
1049
1050 dcu_chain_state = (chk_dbg >> (5 * i)) & 0x1f;
1051 if (dcu_chain_state == 0x6) {
1052 dcu_wait_frdone = true;
1053 chk_dcu |= BIT(i);
1054 }
1055 }
1056
1057 if ((dcu_complete_state == 0x1) && dcu_wait_frdone) {
1058 for_each_set_bit(i, &chk_dcu, ATH9K_NUM_TX_QUEUES) {
1059 if (ath9k_hw_verify_hang(ah, i))
1060 return true;
1061 }
1062 }
1063exit:
1064 return false;
1065}
1066
Luis R. Rodriguezb3950e62010-04-15 17:39:03 -04001067/* Sets up the AR9003 hardware familiy callbacks */
1068void ar9003_hw_attach_ops(struct ath_hw *ah)
1069{
1070 struct ath_hw_private_ops *priv_ops = ath9k_hw_private_ops(ah);
1071 struct ath_hw_ops *ops = ath9k_hw_ops(ah);
1072
Felix Fietkau6aaacd82013-01-13 19:54:58 +01001073 ar9003_hw_init_mode_regs(ah);
Luis R. Rodriguezc14a85d2010-04-15 17:39:21 -04001074 priv_ops->init_mode_gain_regs = ar9003_hw_init_mode_gain_regs;
Sujith Manoharan45987022013-12-24 10:44:18 +05301075 priv_ops->init_hang_checks = ar9003_hw_init_hang_checks;
Sujith Manoharan990de2b2013-12-24 10:44:19 +05301076 priv_ops->detect_mac_hang = ar9003_hw_detect_mac_hang;
Luis R. Rodriguezb3950e62010-04-15 17:39:03 -04001077
1078 ops->config_pci_powersave = ar9003_hw_configpcipowersave;
1079
1080 ar9003_hw_attach_phy_ops(ah);
1081 ar9003_hw_attach_calib_ops(ah);
1082 ar9003_hw_attach_mac_ops(ah);
Luis R. Rodriguezb3950e62010-04-15 17:39:03 -04001083}