Linux-libre 3.18.13-gnu
[librecmc/linux-libre.git] / drivers / net / wireless / ath / ath9k / ar9003_hw.c
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
33 /* General hardware code for the AR9003 hadware family */
34
35 /*
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  */
40 static void ar9003_hw_init_mode_regs(struct ath_hw *ah)
41 {
42         if (AR_SREV_9330_11(ah)) {
43                 /* mac */
44                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
45                                 ar9331_1p1_mac_core);
46                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
47                                 ar9331_1p1_mac_postamble);
48
49                 /* bb */
50                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
51                                 ar9331_1p1_baseband_core);
52                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
53                                 ar9331_1p1_baseband_postamble);
54
55                 /* radio */
56                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
57                                 ar9331_1p1_radio_core);
58
59                 /* soc */
60                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
61                                 ar9331_1p1_soc_preamble);
62                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
63                                 ar9331_1p1_soc_postamble);
64
65                 /* rx/tx gain */
66                 INIT_INI_ARRAY(&ah->iniModesRxGain,
67                                 ar9331_common_rx_gain_1p1);
68                 INIT_INI_ARRAY(&ah->iniModesTxGain,
69                                 ar9331_modes_lowest_ob_db_tx_gain_1p1);
70
71                 /* Japan 2484 Mhz CCK */
72                 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
73                                ar9331_1p1_baseband_core_txfir_coeff_japan_2484);
74
75                 /* additional clock settings */
76                 if (ah->is_clk_25mhz)
77                         INIT_INI_ARRAY(&ah->iniAdditional,
78                                         ar9331_1p1_xtal_25M);
79                 else
80                         INIT_INI_ARRAY(&ah->iniAdditional,
81                                         ar9331_1p1_xtal_40M);
82         } else if (AR_SREV_9330_12(ah)) {
83                 /* mac */
84                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
85                                 ar9331_1p2_mac_core);
86                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
87                                 ar9331_1p2_mac_postamble);
88
89                 /* bb */
90                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
91                                 ar9331_1p2_baseband_core);
92                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
93                                 ar9331_1p2_baseband_postamble);
94
95                 /* radio */
96                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
97                                 ar9331_1p2_radio_core);
98
99                 /* soc */
100                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
101                                 ar9331_1p2_soc_preamble);
102                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
103                                 ar9331_1p2_soc_postamble);
104
105                 /* rx/tx gain */
106                 INIT_INI_ARRAY(&ah->iniModesRxGain,
107                                 ar9331_common_rx_gain_1p2);
108                 INIT_INI_ARRAY(&ah->iniModesTxGain,
109                                 ar9331_modes_lowest_ob_db_tx_gain_1p2);
110
111                 /* Japan 2484 Mhz CCK */
112                 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
113                                ar9331_1p2_baseband_core_txfir_coeff_japan_2484);
114
115                 /* additional clock settings */
116                 if (ah->is_clk_25mhz)
117                         INIT_INI_ARRAY(&ah->iniAdditional,
118                                         ar9331_1p2_xtal_25M);
119                 else
120                         INIT_INI_ARRAY(&ah->iniAdditional,
121                                         ar9331_1p2_xtal_40M);
122         } else if (AR_SREV_9340(ah)) {
123                 /* mac */
124                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
125                                 ar9340_1p0_mac_core);
126                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
127                                 ar9340_1p0_mac_postamble);
128
129                 /* bb */
130                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
131                                 ar9340_1p0_baseband_core);
132                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
133                                 ar9340_1p0_baseband_postamble);
134
135                 /* radio */
136                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
137                                 ar9340_1p0_radio_core);
138                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
139                                 ar9340_1p0_radio_postamble);
140
141                 /* soc */
142                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
143                                 ar9340_1p0_soc_preamble);
144                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
145                                 ar9340_1p0_soc_postamble);
146
147                 /* rx/tx gain */
148                 INIT_INI_ARRAY(&ah->iniModesRxGain,
149                                 ar9340Common_wo_xlna_rx_gain_table_1p0);
150                 INIT_INI_ARRAY(&ah->iniModesTxGain,
151                                 ar9340Modes_high_ob_db_tx_gain_table_1p0);
152
153                 INIT_INI_ARRAY(&ah->iniModesFastClock,
154                                ar9340Modes_fast_clock_1p0);
155                 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
156                                ar9340_1p0_baseband_core_txfir_coeff_japan_2484);
157                 INIT_INI_ARRAY(&ah->ini_dfs,
158                                ar9340_1p0_baseband_postamble_dfs_channel);
159
160                 if (!ah->is_clk_25mhz)
161                         INIT_INI_ARRAY(&ah->iniAdditional,
162                                        ar9340_1p0_radio_core_40M);
163         } else if (AR_SREV_9485_11_OR_LATER(ah)) {
164                 /* mac */
165                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
166                                 ar9485_1_1_mac_core);
167                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
168                                 ar9485_1_1_mac_postamble);
169
170                 /* bb */
171                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_PRE], ar9485_1_1);
172                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
173                                 ar9485_1_1_baseband_core);
174                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
175                                 ar9485_1_1_baseband_postamble);
176
177                 /* radio */
178                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
179                                 ar9485_1_1_radio_core);
180                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
181                                 ar9485_1_1_radio_postamble);
182
183                 /* soc */
184                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
185                                 ar9485_1_1_soc_preamble);
186
187                 /* rx/tx gain */
188                 INIT_INI_ARRAY(&ah->iniModesRxGain,
189                                 ar9485Common_wo_xlna_rx_gain_1_1);
190                 INIT_INI_ARRAY(&ah->iniModesTxGain,
191                                 ar9485_modes_lowest_ob_db_tx_gain_1_1);
192
193                 /* Japan 2484 Mhz CCK */
194                 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
195                                ar9485_1_1_baseband_core_txfir_coeff_japan_2484);
196
197                 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                 }
208         } 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);
233                 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);
237         } else if (AR_SREV_9462_20(ah)) {
238
239                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE], ar9462_2p0_mac_core);
240                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
241                                 ar9462_2p0_mac_postamble);
242
243                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
244                                 ar9462_2p0_baseband_core);
245                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
246                                 ar9462_2p0_baseband_postamble);
247
248                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
249                                 ar9462_2p0_radio_core);
250                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
251                                 ar9462_2p0_radio_postamble);
252                 INIT_INI_ARRAY(&ah->ini_radio_post_sys2ant,
253                                 ar9462_2p0_radio_postamble_sys2ant);
254
255                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
256                                 ar9462_2p0_soc_preamble);
257                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
258                                 ar9462_2p0_soc_postamble);
259
260                 INIT_INI_ARRAY(&ah->iniModesRxGain,
261                                 ar9462_2p0_common_rx_gain);
262
263                 /* Awake -> Sleep Setting */
264                 INIT_INI_ARRAY(&ah->iniPcieSerdes,
265                                ar9462_2p0_pciephy_clkreq_disable_L1);
266                 /* Sleep -> Awake Setting */
267                 INIT_INI_ARRAY(&ah->iniPcieSerdesLowPower,
268                                ar9462_2p0_pciephy_clkreq_disable_L1);
269
270                 /* Fast clock modal settings */
271                 INIT_INI_ARRAY(&ah->iniModesFastClock,
272                                 ar9462_2p0_modes_fast_clock);
273
274                 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
275                                ar9462_2p0_baseband_core_txfir_coeff_japan_2484);
276         } else if (AR_SREV_9550(ah)) {
277                 /* mac */
278                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
279                                 ar955x_1p0_mac_core);
280                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
281                                 ar955x_1p0_mac_postamble);
282
283                 /* bb */
284                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
285                                 ar955x_1p0_baseband_core);
286                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
287                                 ar955x_1p0_baseband_postamble);
288
289                 /* radio */
290                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
291                                 ar955x_1p0_radio_core);
292                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
293                                 ar955x_1p0_radio_postamble);
294
295                 /* soc */
296                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
297                                 ar955x_1p0_soc_preamble);
298                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
299                                 ar955x_1p0_soc_postamble);
300
301                 /* rx/tx gain */
302                 INIT_INI_ARRAY(&ah->iniModesRxGain,
303                         ar955x_1p0_common_wo_xlna_rx_gain_table);
304                 INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
305                         ar955x_1p0_common_wo_xlna_rx_gain_bounds);
306                 INIT_INI_ARRAY(&ah->iniModesTxGain,
307                                 ar955x_1p0_modes_xpa_tx_gain_table);
308
309                 /* Fast clock modal settings */
310                 INIT_INI_ARRAY(&ah->iniModesFastClock,
311                                 ar955x_1p0_modes_fast_clock);
312         } 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);
317                 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                 }
328                 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);
336                 INIT_INI_ARRAY(&ah->iniModesRxGain,
337                                qca953x_1p0_common_wo_xlna_rx_gain_table);
338                 INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
339                                qca953x_1p0_common_wo_xlna_rx_gain_bounds);
340                 INIT_INI_ARRAY(&ah->iniModesTxGain,
341                                qca953x_1p0_modes_no_xpa_tx_gain_table);
342                 INIT_INI_ARRAY(&ah->iniModesFastClock,
343                                qca953x_1p0_modes_fast_clock);
344         } else if (AR_SREV_9580(ah)) {
345                 /* mac */
346                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
347                                 ar9580_1p0_mac_core);
348                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
349                                 ar9580_1p0_mac_postamble);
350
351                 /* bb */
352                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
353                                 ar9580_1p0_baseband_core);
354                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
355                                 ar9580_1p0_baseband_postamble);
356
357                 /* radio */
358                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
359                                 ar9580_1p0_radio_core);
360                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
361                                 ar9580_1p0_radio_postamble);
362
363                 /* soc */
364                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
365                                 ar9580_1p0_soc_preamble);
366                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
367                                 ar9580_1p0_soc_postamble);
368
369                 /* rx/tx gain */
370                 INIT_INI_ARRAY(&ah->iniModesRxGain,
371                                 ar9580_1p0_rx_gain_table);
372                 INIT_INI_ARRAY(&ah->iniModesTxGain,
373                                 ar9580_1p0_low_ob_db_tx_gain_table);
374
375                 INIT_INI_ARRAY(&ah->iniModesFastClock,
376                                ar9580_1p0_modes_fast_clock);
377                 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
378                                ar9580_1p0_baseband_core_txfir_coeff_japan_2484);
379                 INIT_INI_ARRAY(&ah->ini_dfs,
380                                ar9580_1p0_baseband_postamble_dfs_channel);
381         } else if (AR_SREV_9565_11_OR_LATER(ah)) {
382                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
383                                ar9565_1p1_mac_core);
384                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
385                                ar9565_1p1_mac_postamble);
386
387                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
388                                ar9565_1p1_baseband_core);
389                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
390                                ar9565_1p1_baseband_postamble);
391
392                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
393                                ar9565_1p1_radio_core);
394                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
395                                ar9565_1p1_radio_postamble);
396
397                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
398                                ar9565_1p1_soc_preamble);
399                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
400                                ar9565_1p1_soc_postamble);
401
402                 INIT_INI_ARRAY(&ah->iniModesRxGain,
403                                ar9565_1p1_Common_rx_gain_table);
404                 INIT_INI_ARRAY(&ah->iniModesTxGain,
405                                ar9565_1p1_Modes_lowest_ob_db_tx_gain_table);
406
407                 INIT_INI_ARRAY(&ah->iniPcieSerdes,
408                                ar9565_1p1_pciephy_clkreq_disable_L1);
409                 INIT_INI_ARRAY(&ah->iniPcieSerdesLowPower,
410                                ar9565_1p1_pciephy_clkreq_disable_L1);
411
412                 INIT_INI_ARRAY(&ah->iniModesFastClock,
413                                 ar9565_1p1_modes_fast_clock);
414                 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
415                                ar9565_1p1_baseband_core_txfir_coeff_japan_2484);
416         } else if (AR_SREV_9565(ah)) {
417                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
418                                ar9565_1p0_mac_core);
419                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
420                                ar9565_1p0_mac_postamble);
421
422                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
423                                ar9565_1p0_baseband_core);
424                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
425                                ar9565_1p0_baseband_postamble);
426
427                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
428                                ar9565_1p0_radio_core);
429                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
430                                ar9565_1p0_radio_postamble);
431
432                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
433                                ar9565_1p0_soc_preamble);
434                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
435                                ar9565_1p0_soc_postamble);
436
437                 INIT_INI_ARRAY(&ah->iniModesRxGain,
438                                ar9565_1p0_Common_rx_gain_table);
439                 INIT_INI_ARRAY(&ah->iniModesTxGain,
440                                ar9565_1p0_Modes_lowest_ob_db_tx_gain_table);
441
442                 INIT_INI_ARRAY(&ah->iniPcieSerdes,
443                                ar9565_1p0_pciephy_clkreq_disable_L1);
444                 INIT_INI_ARRAY(&ah->iniPcieSerdesLowPower,
445                                ar9565_1p0_pciephy_clkreq_disable_L1);
446
447                 INIT_INI_ARRAY(&ah->iniModesFastClock,
448                                 ar9565_1p0_modes_fast_clock);
449                 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
450                                ar9565_1p0_baseband_core_txfir_coeff_japan_2484);
451         } else {
452                 /* mac */
453                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
454                                 ar9300_2p2_mac_core);
455                 INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
456                                 ar9300_2p2_mac_postamble);
457
458                 /* bb */
459                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
460                                 ar9300_2p2_baseband_core);
461                 INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
462                                 ar9300_2p2_baseband_postamble);
463
464                 /* radio */
465                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
466                                 ar9300_2p2_radio_core);
467                 INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
468                                 ar9300_2p2_radio_postamble);
469
470                 /* soc */
471                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
472                                 ar9300_2p2_soc_preamble);
473                 INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
474                                 ar9300_2p2_soc_postamble);
475
476                 /* rx/tx gain */
477                 INIT_INI_ARRAY(&ah->iniModesRxGain,
478                                 ar9300Common_rx_gain_table_2p2);
479                 INIT_INI_ARRAY(&ah->iniModesTxGain,
480                                 ar9300Modes_lowest_ob_db_tx_gain_table_2p2);
481
482                 /* Load PCIE SERDES settings from INI */
483
484                 /* Awake Setting */
485
486                 INIT_INI_ARRAY(&ah->iniPcieSerdes,
487                                 ar9300PciePhy_pll_on_clkreq_disable_L1_2p2);
488
489                 /* Sleep Setting */
490
491                 INIT_INI_ARRAY(&ah->iniPcieSerdesLowPower,
492                                 ar9300PciePhy_pll_on_clkreq_disable_L1_2p2);
493
494                 /* Fast clock modal settings */
495                 INIT_INI_ARRAY(&ah->iniModesFastClock,
496                                ar9300Modes_fast_clock_2p2);
497                 INIT_INI_ARRAY(&ah->iniCckfirJapan2484,
498                                ar9300_2p2_baseband_core_txfir_coeff_japan_2484);
499                 INIT_INI_ARRAY(&ah->ini_dfs,
500                                ar9300_2p2_baseband_postamble_dfs_channel);
501         }
502 }
503
504 static void ar9003_tx_gain_table_mode0(struct ath_hw *ah)
505 {
506         if (AR_SREV_9330_12(ah))
507                 INIT_INI_ARRAY(&ah->iniModesTxGain,
508                         ar9331_modes_lowest_ob_db_tx_gain_1p2);
509         else if (AR_SREV_9330_11(ah))
510                 INIT_INI_ARRAY(&ah->iniModesTxGain,
511                         ar9331_modes_lowest_ob_db_tx_gain_1p1);
512         else if (AR_SREV_9340(ah))
513                 INIT_INI_ARRAY(&ah->iniModesTxGain,
514                         ar9340Modes_lowest_ob_db_tx_gain_table_1p0);
515         else if (AR_SREV_9485_11_OR_LATER(ah))
516                 INIT_INI_ARRAY(&ah->iniModesTxGain,
517                         ar9485_modes_lowest_ob_db_tx_gain_1_1);
518         else if (AR_SREV_9550(ah))
519                 INIT_INI_ARRAY(&ah->iniModesTxGain,
520                         ar955x_1p0_modes_xpa_tx_gain_table);
521         else if (AR_SREV_9531(ah))
522                 INIT_INI_ARRAY(&ah->iniModesTxGain,
523                         qca953x_1p0_modes_xpa_tx_gain_table);
524         else if (AR_SREV_9580(ah))
525                 INIT_INI_ARRAY(&ah->iniModesTxGain,
526                         ar9580_1p0_lowest_ob_db_tx_gain_table);
527         else if (AR_SREV_9462_21(ah))
528                 INIT_INI_ARRAY(&ah->iniModesTxGain,
529                         ar9462_2p1_modes_low_ob_db_tx_gain);
530         else if (AR_SREV_9462_20(ah))
531                 INIT_INI_ARRAY(&ah->iniModesTxGain,
532                         ar9462_2p0_modes_low_ob_db_tx_gain);
533         else if (AR_SREV_9565_11(ah))
534                 INIT_INI_ARRAY(&ah->iniModesTxGain,
535                                ar9565_1p1_modes_low_ob_db_tx_gain_table);
536         else if (AR_SREV_9565(ah))
537                 INIT_INI_ARRAY(&ah->iniModesTxGain,
538                                ar9565_1p0_modes_low_ob_db_tx_gain_table);
539         else
540                 INIT_INI_ARRAY(&ah->iniModesTxGain,
541                         ar9300Modes_lowest_ob_db_tx_gain_table_2p2);
542 }
543
544 static void ar9003_tx_gain_table_mode1(struct ath_hw *ah)
545 {
546         if (AR_SREV_9330_12(ah))
547                 INIT_INI_ARRAY(&ah->iniModesTxGain,
548                         ar9331_modes_high_ob_db_tx_gain_1p2);
549         else if (AR_SREV_9330_11(ah))
550                 INIT_INI_ARRAY(&ah->iniModesTxGain,
551                         ar9331_modes_high_ob_db_tx_gain_1p1);
552         else if (AR_SREV_9340(ah))
553                 INIT_INI_ARRAY(&ah->iniModesTxGain,
554                         ar9340Modes_high_ob_db_tx_gain_table_1p0);
555         else if (AR_SREV_9485_11_OR_LATER(ah))
556                 INIT_INI_ARRAY(&ah->iniModesTxGain,
557                         ar9485Modes_high_ob_db_tx_gain_1_1);
558         else if (AR_SREV_9580(ah))
559                 INIT_INI_ARRAY(&ah->iniModesTxGain,
560                         ar9580_1p0_high_ob_db_tx_gain_table);
561         else if (AR_SREV_9550(ah))
562                 INIT_INI_ARRAY(&ah->iniModesTxGain,
563                         ar955x_1p0_modes_no_xpa_tx_gain_table);
564         else if (AR_SREV_9531(ah)) {
565                 if (AR_SREV_9531_11(ah))
566                         INIT_INI_ARRAY(&ah->iniModesTxGain,
567                                        qca953x_1p1_modes_no_xpa_tx_gain_table);
568                 else
569                         INIT_INI_ARRAY(&ah->iniModesTxGain,
570                                        qca953x_1p0_modes_no_xpa_tx_gain_table);
571         } else if (AR_SREV_9462_21(ah))
572                 INIT_INI_ARRAY(&ah->iniModesTxGain,
573                         ar9462_2p1_modes_high_ob_db_tx_gain);
574         else if (AR_SREV_9462_20(ah))
575                 INIT_INI_ARRAY(&ah->iniModesTxGain,
576                         ar9462_2p0_modes_high_ob_db_tx_gain);
577         else if (AR_SREV_9565_11(ah))
578                 INIT_INI_ARRAY(&ah->iniModesTxGain,
579                                ar9565_1p1_modes_high_ob_db_tx_gain_table);
580         else if (AR_SREV_9565(ah))
581                 INIT_INI_ARRAY(&ah->iniModesTxGain,
582                                ar9565_1p0_modes_high_ob_db_tx_gain_table);
583         else
584                 INIT_INI_ARRAY(&ah->iniModesTxGain,
585                         ar9300Modes_high_ob_db_tx_gain_table_2p2);
586 }
587
588 static void ar9003_tx_gain_table_mode2(struct ath_hw *ah)
589 {
590         if (AR_SREV_9330_12(ah))
591                 INIT_INI_ARRAY(&ah->iniModesTxGain,
592                         ar9331_modes_low_ob_db_tx_gain_1p2);
593         else if (AR_SREV_9330_11(ah))
594                 INIT_INI_ARRAY(&ah->iniModesTxGain,
595                         ar9331_modes_low_ob_db_tx_gain_1p1);
596         else if (AR_SREV_9340(ah))
597                 INIT_INI_ARRAY(&ah->iniModesTxGain,
598                         ar9340Modes_low_ob_db_tx_gain_table_1p0);
599         else if (AR_SREV_9485_11_OR_LATER(ah))
600                 INIT_INI_ARRAY(&ah->iniModesTxGain,
601                         ar9485Modes_low_ob_db_tx_gain_1_1);
602         else if (AR_SREV_9580(ah))
603                 INIT_INI_ARRAY(&ah->iniModesTxGain,
604                         ar9580_1p0_low_ob_db_tx_gain_table);
605         else if (AR_SREV_9565_11(ah))
606                 INIT_INI_ARRAY(&ah->iniModesTxGain,
607                                ar9565_1p1_modes_low_ob_db_tx_gain_table);
608         else if (AR_SREV_9565(ah))
609                 INIT_INI_ARRAY(&ah->iniModesTxGain,
610                                ar9565_1p0_modes_low_ob_db_tx_gain_table);
611         else
612                 INIT_INI_ARRAY(&ah->iniModesTxGain,
613                         ar9300Modes_low_ob_db_tx_gain_table_2p2);
614 }
615
616 static void ar9003_tx_gain_table_mode3(struct ath_hw *ah)
617 {
618         if (AR_SREV_9330_12(ah))
619                 INIT_INI_ARRAY(&ah->iniModesTxGain,
620                         ar9331_modes_high_power_tx_gain_1p2);
621         else if (AR_SREV_9330_11(ah))
622                 INIT_INI_ARRAY(&ah->iniModesTxGain,
623                         ar9331_modes_high_power_tx_gain_1p1);
624         else if (AR_SREV_9340(ah))
625                 INIT_INI_ARRAY(&ah->iniModesTxGain,
626                         ar9340Modes_high_power_tx_gain_table_1p0);
627         else if (AR_SREV_9485_11_OR_LATER(ah))
628                 INIT_INI_ARRAY(&ah->iniModesTxGain,
629                         ar9485Modes_high_power_tx_gain_1_1);
630         else if (AR_SREV_9580(ah))
631                 INIT_INI_ARRAY(&ah->iniModesTxGain,
632                         ar9580_1p0_high_power_tx_gain_table);
633         else if (AR_SREV_9565_11(ah))
634                 INIT_INI_ARRAY(&ah->iniModesTxGain,
635                                ar9565_1p1_modes_high_power_tx_gain_table);
636         else if (AR_SREV_9565(ah))
637                 INIT_INI_ARRAY(&ah->iniModesTxGain,
638                                ar9565_1p0_modes_high_power_tx_gain_table);
639         else {
640                 if (ah->config.tx_gain_buffalo)
641                         INIT_INI_ARRAY(&ah->iniModesTxGain,
642                                        ar9300Modes_high_power_tx_gain_table_buffalo);
643                 else
644                         INIT_INI_ARRAY(&ah->iniModesTxGain,
645                                        ar9300Modes_high_power_tx_gain_table_2p2);
646         }
647 }
648
649 static void ar9003_tx_gain_table_mode4(struct ath_hw *ah)
650 {
651         if (AR_SREV_9340(ah))
652                 INIT_INI_ARRAY(&ah->iniModesTxGain,
653                         ar9340Modes_mixed_ob_db_tx_gain_table_1p0);
654         else if (AR_SREV_9580(ah))
655                 INIT_INI_ARRAY(&ah->iniModesTxGain,
656                         ar9580_1p0_mixed_ob_db_tx_gain_table);
657         else if (AR_SREV_9462_21(ah))
658                 INIT_INI_ARRAY(&ah->iniModesTxGain,
659                        ar9462_2p1_modes_mix_ob_db_tx_gain);
660         else if (AR_SREV_9462_20(ah))
661                 INIT_INI_ARRAY(&ah->iniModesTxGain,
662                        ar9462_2p0_modes_mix_ob_db_tx_gain);
663         else
664                 INIT_INI_ARRAY(&ah->iniModesTxGain,
665                         ar9300Modes_mixed_ob_db_tx_gain_table_2p2);
666 }
667
668 static void ar9003_tx_gain_table_mode5(struct ath_hw *ah)
669 {
670         if (AR_SREV_9485_11_OR_LATER(ah))
671                 INIT_INI_ARRAY(&ah->iniModesTxGain,
672                         ar9485Modes_green_ob_db_tx_gain_1_1);
673         else if (AR_SREV_9340(ah))
674                 INIT_INI_ARRAY(&ah->iniModesTxGain,
675                         ar9340Modes_ub124_tx_gain_table_1p0);
676         else if (AR_SREV_9580(ah))
677                 INIT_INI_ARRAY(&ah->iniModesTxGain,
678                         ar9580_1p0_type5_tx_gain_table);
679         else if (AR_SREV_9300_22(ah))
680                 INIT_INI_ARRAY(&ah->iniModesTxGain,
681                         ar9300Modes_type5_tx_gain_table_2p2);
682 }
683
684 static void ar9003_tx_gain_table_mode6(struct ath_hw *ah)
685 {
686         if (AR_SREV_9340(ah))
687                 INIT_INI_ARRAY(&ah->iniModesTxGain,
688                         ar9340Modes_low_ob_db_and_spur_tx_gain_table_1p0);
689         else if (AR_SREV_9485_11_OR_LATER(ah))
690                 INIT_INI_ARRAY(&ah->iniModesTxGain,
691                         ar9485Modes_green_spur_ob_db_tx_gain_1_1);
692         else if (AR_SREV_9580(ah))
693                 INIT_INI_ARRAY(&ah->iniModesTxGain,
694                         ar9580_1p0_type6_tx_gain_table);
695 }
696
697 static void ar9003_tx_gain_table_mode7(struct ath_hw *ah)
698 {
699         if (AR_SREV_9340(ah))
700                 INIT_INI_ARRAY(&ah->iniModesTxGain,
701                                ar9340_cus227_tx_gain_table_1p0);
702 }
703
704 typedef void (*ath_txgain_tab)(struct ath_hw *ah);
705
706 static void ar9003_tx_gain_table_apply(struct ath_hw *ah)
707 {
708         static const ath_txgain_tab modes[] = {
709                 ar9003_tx_gain_table_mode0,
710                 ar9003_tx_gain_table_mode1,
711                 ar9003_tx_gain_table_mode2,
712                 ar9003_tx_gain_table_mode3,
713                 ar9003_tx_gain_table_mode4,
714                 ar9003_tx_gain_table_mode5,
715                 ar9003_tx_gain_table_mode6,
716                 ar9003_tx_gain_table_mode7,
717         };
718         int idx = ar9003_hw_get_tx_gain_idx(ah);
719
720         if (idx >= ARRAY_SIZE(modes))
721                 idx = 0;
722
723         modes[idx](ah);
724 }
725
726 static void ar9003_rx_gain_table_mode0(struct ath_hw *ah)
727 {
728         if (AR_SREV_9330_12(ah))
729                 INIT_INI_ARRAY(&ah->iniModesRxGain,
730                                 ar9331_common_rx_gain_1p2);
731         else if (AR_SREV_9330_11(ah))
732                 INIT_INI_ARRAY(&ah->iniModesRxGain,
733                                 ar9331_common_rx_gain_1p1);
734         else if (AR_SREV_9340(ah))
735                 INIT_INI_ARRAY(&ah->iniModesRxGain,
736                                 ar9340Common_rx_gain_table_1p0);
737         else if (AR_SREV_9485_11_OR_LATER(ah))
738                 INIT_INI_ARRAY(&ah->iniModesRxGain,
739                                ar9485_common_rx_gain_1_1);
740         else if (AR_SREV_9550(ah)) {
741                 INIT_INI_ARRAY(&ah->iniModesRxGain,
742                                 ar955x_1p0_common_rx_gain_table);
743                 INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
744                                 ar955x_1p0_common_rx_gain_bounds);
745         } else if (AR_SREV_9531(ah)) {
746                 INIT_INI_ARRAY(&ah->iniModesRxGain,
747                                qca953x_1p0_common_rx_gain_table);
748                 INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
749                                qca953x_1p0_common_rx_gain_bounds);
750         } else if (AR_SREV_9580(ah))
751                 INIT_INI_ARRAY(&ah->iniModesRxGain,
752                                 ar9580_1p0_rx_gain_table);
753         else if (AR_SREV_9462_21(ah))
754                 INIT_INI_ARRAY(&ah->iniModesRxGain,
755                                 ar9462_2p1_common_rx_gain);
756         else if (AR_SREV_9462_20(ah))
757                 INIT_INI_ARRAY(&ah->iniModesRxGain,
758                                 ar9462_2p0_common_rx_gain);
759         else if (AR_SREV_9565_11(ah))
760                 INIT_INI_ARRAY(&ah->iniModesRxGain,
761                                ar9565_1p1_Common_rx_gain_table);
762         else if (AR_SREV_9565(ah))
763                 INIT_INI_ARRAY(&ah->iniModesRxGain,
764                                ar9565_1p0_Common_rx_gain_table);
765         else
766                 INIT_INI_ARRAY(&ah->iniModesRxGain,
767                                 ar9300Common_rx_gain_table_2p2);
768 }
769
770 static void ar9003_rx_gain_table_mode1(struct ath_hw *ah)
771 {
772         if (AR_SREV_9330_12(ah))
773                 INIT_INI_ARRAY(&ah->iniModesRxGain,
774                         ar9331_common_wo_xlna_rx_gain_1p2);
775         else if (AR_SREV_9330_11(ah))
776                 INIT_INI_ARRAY(&ah->iniModesRxGain,
777                         ar9331_common_wo_xlna_rx_gain_1p1);
778         else if (AR_SREV_9340(ah))
779                 INIT_INI_ARRAY(&ah->iniModesRxGain,
780                         ar9340Common_wo_xlna_rx_gain_table_1p0);
781         else if (AR_SREV_9485_11_OR_LATER(ah))
782                 INIT_INI_ARRAY(&ah->iniModesRxGain,
783                         ar9485Common_wo_xlna_rx_gain_1_1);
784         else if (AR_SREV_9462_21(ah))
785                 INIT_INI_ARRAY(&ah->iniModesRxGain,
786                         ar9462_2p1_common_wo_xlna_rx_gain);
787         else if (AR_SREV_9462_20(ah))
788                 INIT_INI_ARRAY(&ah->iniModesRxGain,
789                         ar9462_2p0_common_wo_xlna_rx_gain);
790         else if (AR_SREV_9550(ah)) {
791                 INIT_INI_ARRAY(&ah->iniModesRxGain,
792                         ar955x_1p0_common_wo_xlna_rx_gain_table);
793                 INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
794                         ar955x_1p0_common_wo_xlna_rx_gain_bounds);
795         } else if (AR_SREV_9531(ah)) {
796                 INIT_INI_ARRAY(&ah->iniModesRxGain,
797                                qca953x_1p0_common_wo_xlna_rx_gain_table);
798                 INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
799                                qca953x_1p0_common_wo_xlna_rx_gain_bounds);
800         } else if (AR_SREV_9580(ah))
801                 INIT_INI_ARRAY(&ah->iniModesRxGain,
802                         ar9580_1p0_wo_xlna_rx_gain_table);
803         else if (AR_SREV_9565_11(ah))
804                 INIT_INI_ARRAY(&ah->iniModesRxGain,
805                                ar9565_1p1_common_wo_xlna_rx_gain_table);
806         else if (AR_SREV_9565(ah))
807                 INIT_INI_ARRAY(&ah->iniModesRxGain,
808                                ar9565_1p0_common_wo_xlna_rx_gain_table);
809         else
810                 INIT_INI_ARRAY(&ah->iniModesRxGain,
811                         ar9300Common_wo_xlna_rx_gain_table_2p2);
812 }
813
814 static void ar9003_rx_gain_table_mode2(struct ath_hw *ah)
815 {
816         if (AR_SREV_9462_21(ah)) {
817                 INIT_INI_ARRAY(&ah->iniModesRxGain,
818                                ar9462_2p1_common_mixed_rx_gain);
819                 INIT_INI_ARRAY(&ah->ini_modes_rxgain_bb_core,
820                                ar9462_2p1_baseband_core_mix_rxgain);
821                 INIT_INI_ARRAY(&ah->ini_modes_rxgain_bb_postamble,
822                                ar9462_2p1_baseband_postamble_mix_rxgain);
823                 INIT_INI_ARRAY(&ah->ini_modes_rxgain_5g_xlna,
824                                ar9462_2p1_baseband_postamble_5g_xlna);
825         } else if (AR_SREV_9462_20(ah)) {
826                 INIT_INI_ARRAY(&ah->iniModesRxGain,
827                                ar9462_2p0_common_mixed_rx_gain);
828                 INIT_INI_ARRAY(&ah->ini_modes_rxgain_bb_core,
829                                ar9462_2p0_baseband_core_mix_rxgain);
830                 INIT_INI_ARRAY(&ah->ini_modes_rxgain_bb_postamble,
831                                ar9462_2p0_baseband_postamble_mix_rxgain);
832                 INIT_INI_ARRAY(&ah->ini_modes_rxgain_5g_xlna,
833                                ar9462_2p0_baseband_postamble_5g_xlna);
834         }
835 }
836
837 static void ar9003_rx_gain_table_mode3(struct ath_hw *ah)
838 {
839         if (AR_SREV_9462_21(ah)) {
840                 INIT_INI_ARRAY(&ah->iniModesRxGain,
841                                ar9462_2p1_common_5g_xlna_only_rxgain);
842                 INIT_INI_ARRAY(&ah->ini_modes_rxgain_5g_xlna,
843                                ar9462_2p1_baseband_postamble_5g_xlna);
844         } else if (AR_SREV_9462_20(ah)) {
845                 INIT_INI_ARRAY(&ah->iniModesRxGain,
846                                ar9462_2p0_common_5g_xlna_only_rxgain);
847                 INIT_INI_ARRAY(&ah->ini_modes_rxgain_5g_xlna,
848                                ar9462_2p0_baseband_postamble_5g_xlna);
849         }
850 }
851
852 static void ar9003_rx_gain_table_apply(struct ath_hw *ah)
853 {
854         switch (ar9003_hw_get_rx_gain_idx(ah)) {
855         case 0:
856         default:
857                 ar9003_rx_gain_table_mode0(ah);
858                 break;
859         case 1:
860                 ar9003_rx_gain_table_mode1(ah);
861                 break;
862         case 2:
863                 ar9003_rx_gain_table_mode2(ah);
864                 break;
865         case 3:
866                 ar9003_rx_gain_table_mode3(ah);
867                 break;
868         }
869 }
870
871 /* set gain table pointers according to values read from the eeprom */
872 static void ar9003_hw_init_mode_gain_regs(struct ath_hw *ah)
873 {
874         ar9003_tx_gain_table_apply(ah);
875         ar9003_rx_gain_table_apply(ah);
876 }
877
878 /*
879  * Helper for ASPM support.
880  *
881  * Disable PLL when in L0s as well as receiver clock when in L1.
882  * This power saving option must be enabled through the SerDes.
883  *
884  * Programming the SerDes must go through the same 288 bit serial shift
885  * register as the other analog registers.  Hence the 9 writes.
886  */
887 static void ar9003_hw_configpcipowersave(struct ath_hw *ah,
888                                          bool power_off)
889 {
890         unsigned int i;
891         struct ar5416IniArray *array;
892
893         /*
894          * Increase L1 Entry Latency. Some WB222 boards don't have
895          * this change in eeprom/OTP.
896          *
897          */
898         if (AR_SREV_9462(ah)) {
899                 u32 val = ah->config.aspm_l1_fix;
900                 if ((val & 0xff000000) == 0x17000000) {
901                         val &= 0x00ffffff;
902                         val |= 0x27000000;
903                         REG_WRITE(ah, 0x570c, val);
904                 }
905         }
906
907         /* Nothing to do on restore for 11N */
908         if (!power_off /* !restore */) {
909                 /* set bit 19 to allow forcing of pcie core into L1 state */
910                 REG_SET_BIT(ah, AR_PCIE_PM_CTRL, AR_PCIE_PM_CTRL_ENA);
911                 REG_WRITE(ah, AR_WA, ah->WARegVal);
912         }
913
914         /*
915          * Configire PCIE after Ini init. SERDES values now come from ini file
916          * This enables PCIe low power mode.
917          */
918         array = power_off ? &ah->iniPcieSerdes :
919                 &ah->iniPcieSerdesLowPower;
920
921         for (i = 0; i < array->ia_rows; i++) {
922                 REG_WRITE(ah,
923                           INI_RA(array, i, 0),
924                           INI_RA(array, i, 1));
925         }
926 }
927
928 static void ar9003_hw_init_hang_checks(struct ath_hw *ah)
929 {
930         /*
931          * All chips support detection of BB/MAC hangs.
932          */
933         ah->config.hw_hang_checks |= HW_BB_WATCHDOG;
934         ah->config.hw_hang_checks |= HW_MAC_HANG;
935
936         /*
937          * This is not required for AR9580 1.0
938          */
939         if (AR_SREV_9300_22(ah))
940                 ah->config.hw_hang_checks |= HW_PHYRESTART_CLC_WAR;
941
942         if (AR_SREV_9330(ah))
943                 ah->bb_watchdog_timeout_ms = 85;
944         else
945                 ah->bb_watchdog_timeout_ms = 25;
946 }
947
948 /*
949  * MAC HW hang check
950  * =================
951  *
952  * Signature: dcu_chain_state is 0x6 and dcu_complete_state is 0x1.
953  *
954  * The state of each DCU chain (mapped to TX queues) is available from these
955  * DMA debug registers:
956  *
957  * Chain 0 state : Bits 4:0   of AR_DMADBG_4
958  * Chain 1 state : Bits 9:5   of AR_DMADBG_4
959  * Chain 2 state : Bits 14:10 of AR_DMADBG_4
960  * Chain 3 state : Bits 19:15 of AR_DMADBG_4
961  * Chain 4 state : Bits 24:20 of AR_DMADBG_4
962  * Chain 5 state : Bits 29:25 of AR_DMADBG_4
963  * Chain 6 state : Bits 4:0   of AR_DMADBG_5
964  * Chain 7 state : Bits 9:5   of AR_DMADBG_5
965  * Chain 8 state : Bits 14:10 of AR_DMADBG_5
966  * Chain 9 state : Bits 19:15 of AR_DMADBG_5
967  *
968  * The DCU chain state "0x6" means "WAIT_FRDONE" - wait for TX frame to be done.
969  */
970
971 #define NUM_STATUS_READS 50
972
973 static bool ath9k_hw_verify_hang(struct ath_hw *ah, unsigned int queue)
974 {
975         u32 dma_dbg_chain, dma_dbg_complete;
976         u8 dcu_chain_state, dcu_complete_state;
977         int i;
978
979         for (i = 0; i < NUM_STATUS_READS; i++) {
980                 if (queue < 6)
981                         dma_dbg_chain = REG_READ(ah, AR_DMADBG_4);
982                 else
983                         dma_dbg_chain = REG_READ(ah, AR_DMADBG_5);
984
985                 dma_dbg_complete = REG_READ(ah, AR_DMADBG_6);
986
987                 dcu_chain_state = (dma_dbg_chain >> (5 * queue)) & 0x1f;
988                 dcu_complete_state = dma_dbg_complete & 0x3;
989
990                 if ((dcu_chain_state != 0x6) || (dcu_complete_state != 0x1))
991                         return false;
992         }
993
994         ath_dbg(ath9k_hw_common(ah), RESET,
995                 "MAC Hang signature found for queue: %d\n", queue);
996
997         return true;
998 }
999
1000 static bool ar9003_hw_detect_mac_hang(struct ath_hw *ah)
1001 {
1002         u32 dma_dbg_4, dma_dbg_5, dma_dbg_6, chk_dbg;
1003         u8 dcu_chain_state, dcu_complete_state;
1004         bool dcu_wait_frdone = false;
1005         unsigned long chk_dcu = 0;
1006         unsigned int i = 0;
1007
1008         dma_dbg_4 = REG_READ(ah, AR_DMADBG_4);
1009         dma_dbg_5 = REG_READ(ah, AR_DMADBG_5);
1010         dma_dbg_6 = REG_READ(ah, AR_DMADBG_6);
1011
1012         dcu_complete_state = dma_dbg_6 & 0x3;
1013         if (dcu_complete_state != 0x1)
1014                 goto exit;
1015
1016         for (i = 0; i < ATH9K_NUM_TX_QUEUES; i++) {
1017                 if (i < 6)
1018                         chk_dbg = dma_dbg_4;
1019                 else
1020                         chk_dbg = dma_dbg_5;
1021
1022                 dcu_chain_state = (chk_dbg >> (5 * i)) & 0x1f;
1023                 if (dcu_chain_state == 0x6) {
1024                         dcu_wait_frdone = true;
1025                         chk_dcu |= BIT(i);
1026                 }
1027         }
1028
1029         if ((dcu_complete_state == 0x1) && dcu_wait_frdone) {
1030                 for_each_set_bit(i, &chk_dcu, ATH9K_NUM_TX_QUEUES) {
1031                         if (ath9k_hw_verify_hang(ah, i))
1032                                 return true;
1033                 }
1034         }
1035 exit:
1036         return false;
1037 }
1038
1039 /* Sets up the AR9003 hardware familiy callbacks */
1040 void ar9003_hw_attach_ops(struct ath_hw *ah)
1041 {
1042         struct ath_hw_private_ops *priv_ops = ath9k_hw_private_ops(ah);
1043         struct ath_hw_ops *ops = ath9k_hw_ops(ah);
1044
1045         ar9003_hw_init_mode_regs(ah);
1046         priv_ops->init_mode_gain_regs = ar9003_hw_init_mode_gain_regs;
1047         priv_ops->init_hang_checks = ar9003_hw_init_hang_checks;
1048         priv_ops->detect_mac_hang = ar9003_hw_detect_mac_hang;
1049
1050         ops->config_pci_powersave = ar9003_hw_configpcipowersave;
1051
1052         ar9003_hw_attach_phy_ops(ah);
1053         ar9003_hw_attach_calib_ops(ah);
1054         ar9003_hw_attach_mac_ops(ah);
1055 }