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(ah), AR_PCIE_PM_CTRL_ENA);
1036 		REG_WRITE(ah, AR_WA(ah), ah->WARegVal);
1037 	}
1038 
1039 	/*
1040 	 * Configure 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 }
1188