1 | /* $NetBSD: arn9280reg.h,v 1.1 2013/03/30 02:53:01 christos Exp $ */ |
2 | /* $OpenBSD: ar9280reg.h,v 1.6 2012/10/20 09:54:20 stsp Exp $ */ |
3 | |
4 | /*- |
5 | * Copyright (c) 2009 Damien Bergamini <damien.bergamini@free.fr> |
6 | * Copyright (c) 2008-2009 Atheros Communications Inc. |
7 | * |
8 | * Permission to use, copy, modify, and/or distribute this software for any |
9 | * purpose with or without fee is hereby granted, provided that the above |
10 | * copyright notice and this permission notice appear in all copies. |
11 | * |
12 | * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES |
13 | * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF |
14 | * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR |
15 | * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES |
16 | * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN |
17 | * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF |
18 | * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |
19 | */ |
20 | |
21 | #ifndef _ARN9280REG_H_ |
22 | #define _ARN9280REG_H_ |
23 | |
24 | #define AR9280_MAX_CHAINS 2 |
25 | |
26 | #define AR9280_PD_GAIN_BOUNDARY_DEFAULT 56 |
27 | #define AR9280_PHY_CCA_MAX_GOOD_VALUE (-112) |
28 | |
29 | #define AR9280_PHY_SYNTH_CONTROL 0x9874 |
30 | |
31 | /* Bits for AR9280_PHY_SYNTH_CONTROL. */ |
32 | #define AR9280_BMODE 0x20000000 |
33 | #define AR9280_FRACMODE 0x10000000 |
34 | #define AR9280_AMODE_REFSEL_M 0x0c000000 |
35 | #define AR9280_AMODE_REFSEL_S 26 |
36 | |
37 | /* |
38 | * NB: The AR9280 uses the same ROM layout than the AR5416. |
39 | */ |
40 | |
41 | /* Macro to "pack" registers to 16-bit to save some .rodata space. */ |
42 | #define P(x) (x) |
43 | |
44 | /* |
45 | * AR9280 2.0 initialization values. |
46 | */ |
47 | static const uint16_t ar9280_2_0_regs[] = { |
48 | P(0x01030), P(0x01070), P(0x010b0), P(0x010f0), P(0x08014), |
49 | P(0x0801c), P(0x08120), P(0x081d0), P(0x08318), P(0x09804), |
50 | P(0x09820), P(0x09824), P(0x09828), P(0x09834), P(0x09838), |
51 | P(0x09840), P(0x09844), P(0x09850), P(0x09858), P(0x0985c), |
52 | P(0x09860), P(0x09864), P(0x09868), P(0x0986c), P(0x09914), |
53 | P(0x09918), P(0x09924), P(0x09944), P(0x09960), P(0x0a960), |
54 | P(0x09964), P(0x0c968), P(0x099b8), P(0x099bc), P(0x099c0), |
55 | P(0x0a204), P(0x0a20c), P(0x0b20c), P(0x0a21c), P(0x0a230), |
56 | P(0x0a23c), P(0x0a250), P(0x0a358), P(0x0a388), P(0x0a3d8), |
57 | P(0x07894) |
58 | }; |
59 | |
60 | static const uint32_t ar9280_2_0_vals_5g20[] = { |
61 | 0x00000230, 0x00000168, 0x00000e60, 0x00000000, 0x03e803e8, |
62 | 0x128d8027, 0x08f04800, 0x00003210, 0x00003e80, 0x00000300, |
63 | 0x02020200, 0x01000e0e, 0x0a020001, 0x00000e0e, 0x00000007, |
64 | 0x206a022e, 0x0372161e, 0x6c4000e2, 0x7ec88d2e, 0x31395d5e, |
65 | 0x00048d18, 0x0001ce00, 0x5ac640d0, 0x06903081, 0x000007d0, |
66 | 0x0000000a, 0xd00a8a0b, 0xffbc1010, 0x00000010, 0x00000010, |
67 | 0x00000210, 0x000003b5, 0x0000001c, 0x00000a00, 0x05eea6d4, |
68 | 0x00000444, 0x00000014, 0x00000014, 0x1883800a, 0x00000000, |
69 | 0x13c88000, 0x001ff000, 0x7999aa02, 0x0c000000, 0x00000000, |
70 | 0x5a508000 |
71 | }; |
72 | |
73 | #ifndef IEEE80211_NO_HT |
74 | static const uint32_t ar9280_2_0_vals_5g40[] = { |
75 | 0x00000460, 0x000002d0, 0x00001cc0, 0x00000000, 0x07d007d0, |
76 | 0x128d804f, 0x08f04800, 0x00003210, 0x00007d00, 0x000003c4, |
77 | 0x02020200, 0x01000e0e, 0x0a020001, 0x00000e0e, 0x00000007, |
78 | 0x206a022e, 0x0372161e, 0x6d4000e2, 0x7ec88d2e, 0x3139605e, |
79 | 0x00048d18, 0x0001ce00, 0x5ac640d0, 0x06903081, 0x00000fa0, |
80 | 0x00000014, 0xd00a8a0b, 0xffbc1010, 0x00000010, 0x00000010, |
81 | 0x00000210, 0x000003b5, 0x0000001c, 0x00000a00, 0x05eea6d4, |
82 | 0x00000444, 0x00000014, 0x00000014, 0x1883800a, 0x00000000, |
83 | 0x13c88000, 0x001ff000, 0x7999aa02, 0x0c000000, 0x00000000, |
84 | 0x5a508000 |
85 | }; |
86 | |
87 | static const uint32_t ar9280_2_0_vals_2g40[] = { |
88 | 0x000002c0, 0x00000318, 0x00007c70, 0x00000000, 0x10801600, |
89 | 0x12e00057, 0x08f04810, 0x0000320a, 0x00006880, 0x000003c4, |
90 | 0x02020200, 0x01000e0e, 0x0a020001, 0x00000e0e, 0x00000007, |
91 | 0x206a012e, 0x037216a0, 0x6d4000e2, 0x7ec84d2e, 0x3139605e, |
92 | 0x00048d20, 0x0001ce00, 0x5ac640d0, 0x06903881, 0x00001130, |
93 | 0x00000268, 0xd00a8a0d, 0xffbc1010, 0x00000010, 0x00000010, |
94 | 0x00000210, 0x000003ce, 0x0000001c, 0x00000c00, 0x05eea6d4, |
95 | 0x00000444, 0x0001f019, 0x0001f019, 0x1883800a, 0x00000210, |
96 | 0x13c88001, 0x0004a000, 0x7999aa0e, 0x08000000, 0x00000000, |
97 | 0x5a508000 |
98 | }; |
99 | #endif |
100 | |
101 | static const uint32_t ar9280_2_0_vals_2g20[] = { |
102 | 0x00000160, 0x0000018c, 0x00003e38, 0x00000000, 0x08400b00, |
103 | 0x12e0002b, 0x08f04810, 0x0000320a, 0x00003440, 0x00000300, |
104 | 0x02020200, 0x01000e0e, 0x0a020001, 0x00000e0e, 0x00000007, |
105 | 0x206a012e, 0x037216a0, 0x6c4000e2, 0x7ec84d2e, 0x31395d5e, |
106 | 0x00048d20, 0x0001ce00, 0x5ac640d0, 0x06903881, 0x00000898, |
107 | 0x0000000b, 0xd00a8a0d, 0xffbc1010, 0x00000010, 0x00000010, |
108 | 0x00000210, 0x000003ce, 0x0000001c, 0x00000c00, 0x05eea6d4, |
109 | 0x00000444, 0x0001f019, 0x0001f019, 0x1883800a, 0x00000108, |
110 | 0x13c88000, 0x0004a000, 0x7999aa0e, 0x0c000000, 0x00000000, |
111 | 0x5a508000 |
112 | }; |
113 | |
114 | static const uint16_t ar9280_2_0_cm_regs[] = { |
115 | P(0x0000c), P(0x00030), P(0x00034), P(0x00040), P(0x00044), |
116 | P(0x00048), P(0x0004c), P(0x00050), P(0x00054), P(0x00800), |
117 | P(0x00804), P(0x00808), P(0x0080c), P(0x00810), P(0x00814), |
118 | P(0x00818), P(0x0081c), P(0x00820), P(0x00824), P(0x01040), |
119 | P(0x01044), P(0x01048), P(0x0104c), P(0x01050), P(0x01054), |
120 | P(0x01058), P(0x0105c), P(0x01060), P(0x01064), P(0x01230), |
121 | P(0x01270), P(0x01038), P(0x01078), P(0x010b8), P(0x010f8), |
122 | P(0x01138), P(0x01178), P(0x011b8), P(0x011f8), P(0x01238), |
123 | P(0x01278), P(0x012b8), P(0x012f8), P(0x01338), P(0x01378), |
124 | P(0x013b8), P(0x013f8), P(0x01438), P(0x01478), P(0x014b8), |
125 | P(0x014f8), P(0x01538), P(0x01578), P(0x015b8), P(0x015f8), |
126 | P(0x01638), P(0x01678), P(0x016b8), P(0x016f8), P(0x01738), |
127 | P(0x01778), P(0x017b8), P(0x017f8), P(0x0103c), P(0x0107c), |
128 | P(0x010bc), P(0x010fc), P(0x0113c), P(0x0117c), P(0x011bc), |
129 | P(0x011fc), P(0x0123c), P(0x0127c), P(0x012bc), P(0x012fc), |
130 | P(0x0133c), P(0x0137c), P(0x013bc), P(0x013fc), P(0x0143c), |
131 | P(0x0147c), P(0x04030), P(0x0403c), P(0x04024), P(0x04060), |
132 | P(0x04064), P(0x07010), P(0x07034), P(0x07038), P(0x08004), |
133 | P(0x08008), P(0x0800c), P(0x08018), P(0x08020), P(0x08038), |
134 | P(0x0803c), P(0x08048), P(0x08054), P(0x08058), P(0x0805c), |
135 | P(0x08060), P(0x08064), P(0x08070), P(0x080c0), P(0x080c4), |
136 | P(0x080c8), P(0x080cc), P(0x080d0), P(0x080d4), P(0x080d8), |
137 | P(0x080e0), P(0x080e4), P(0x080e8), P(0x080ec), P(0x080f0), |
138 | P(0x080f4), P(0x080f8), P(0x080fc), P(0x08100), P(0x08104), |
139 | P(0x08108), P(0x0810c), P(0x08110), P(0x08118), P(0x0811c), |
140 | P(0x08124), P(0x08128), P(0x0812c), P(0x08130), P(0x08134), |
141 | P(0x08138), P(0x0813c), P(0x08144), P(0x08168), P(0x0816c), |
142 | P(0x08170), P(0x08174), P(0x08178), P(0x0817c), P(0x081c0), |
143 | P(0x081ec), P(0x081f0), P(0x081f4), P(0x081f8), P(0x081fc), |
144 | P(0x08200), P(0x08204), P(0x08208), P(0x0820c), P(0x08210), |
145 | P(0x08214), P(0x08218), P(0x0821c), P(0x08220), P(0x08224), |
146 | P(0x08228), P(0x0822c), P(0x08230), P(0x08234), P(0x08238), |
147 | P(0x0823c), P(0x08240), P(0x08244), P(0x08248), P(0x0824c), |
148 | P(0x08250), P(0x08254), P(0x08258), P(0x0825c), P(0x08260), |
149 | P(0x08264), P(0x08270), P(0x08274), P(0x08278), P(0x0827c), |
150 | P(0x08284), P(0x08288), P(0x0828c), P(0x08294), P(0x08298), |
151 | P(0x0829c), P(0x08300), P(0x08314), P(0x08328), P(0x0832c), |
152 | P(0x08330), P(0x08334), P(0x08338), P(0x0833c), P(0x08340), |
153 | P(0x08344), P(0x09808), P(0x0980c), P(0x09810), P(0x09814), |
154 | P(0x0981c), P(0x0982c), P(0x09830), P(0x0983c), P(0x0984c), |
155 | P(0x0a84c), P(0x09854), P(0x09900), P(0x09904), P(0x09908), |
156 | P(0x0990c), P(0x09910), P(0x0991c), P(0x09920), P(0x0a920), |
157 | P(0x09928), P(0x0992c), P(0x09934), P(0x09938), P(0x0993c), |
158 | P(0x09948), P(0x0994c), P(0x09954), P(0x09958), P(0x09940), |
159 | P(0x0c95c), P(0x09970), P(0x09974), P(0x09978), P(0x0997c), |
160 | P(0x09980), P(0x09984), P(0x09988), P(0x0998c), P(0x09990), |
161 | P(0x09994), P(0x09998), P(0x0999c), P(0x099a0), P(0x099a4), |
162 | P(0x099a8), P(0x099ac), P(0x099b0), P(0x099b4), P(0x099c4), |
163 | P(0x099c8), P(0x099cc), P(0x099d0), P(0x099d4), P(0x099d8), |
164 | P(0x099dc), P(0x099e0), P(0x099e4), P(0x099e8), P(0x099ec), |
165 | P(0x099f0), P(0x099fc), P(0x0a208), P(0x0a210), P(0x0a214), |
166 | P(0x0a218), P(0x0a220), P(0x0a224), P(0x0a228), P(0x0a22c), |
167 | P(0x0a234), P(0x0a238), P(0x0a240), P(0x0a244), P(0x0a248), |
168 | P(0x0a24c), P(0x0a254), P(0x0a258), P(0x0a25c), P(0x0a260), |
169 | P(0x0a268), P(0x0a26c), P(0x0b26c), P(0x0d270), P(0x0a278), |
170 | P(0x0d35c), P(0x0d360), P(0x0d364), P(0x0d368), P(0x0d36c), |
171 | P(0x0d370), P(0x0d374), P(0x0d378), P(0x0d37c), P(0x0d380), |
172 | P(0x0d384), P(0x0a38c), P(0x0a390), P(0x0a394), P(0x0a398), |
173 | P(0x0a39c), P(0x0a3a0), P(0x0a3a4), P(0x0a3a8), P(0x0a3ac), |
174 | P(0x0a3b0), P(0x0a3b4), P(0x0a3b8), P(0x0a3bc), P(0x0a3c0), |
175 | P(0x0a3c4), P(0x0a3c8), P(0x0a3cc), P(0x0a3d0), P(0x0a3d4), |
176 | P(0x0a3dc), P(0x0a3e0), P(0x0a3e4), P(0x0a3e8), P(0x07800), |
177 | P(0x07804), P(0x07808), P(0x0780c), P(0x07810), P(0x07818), |
178 | P(0x07824), P(0x07828), P(0x0782c), P(0x07830), P(0x07834), |
179 | P(0x0783c), P(0x07848), P(0x0784c), P(0x07850), P(0x07854), |
180 | P(0x07858), P(0x07860), P(0x07864), P(0x07868), P(0x0786c), |
181 | P(0x07870), P(0x07874), P(0x07878), P(0x0787c), P(0x07880), |
182 | P(0x07884), P(0x07888), P(0x0788c), P(0x07890), P(0x07898) |
183 | }; |
184 | |
185 | static const uint32_t ar9280_2_0_cm_vals[] = { |
186 | 0x00000000, 0x00020015, 0x00000005, 0x00000000, 0x00000008, |
187 | 0x00000008, 0x00000010, 0x00000000, 0x0000001f, 0x00000000, |
188 | 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, |
189 | 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x002ffc0f, |
190 | 0x002ffc0f, 0x002ffc0f, 0x002ffc0f, 0x002ffc0f, 0x002ffc0f, |
191 | 0x002ffc0f, 0x002ffc0f, 0x002ffc0f, 0x002ffc0f, 0x00000000, |
192 | 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, |
193 | 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, |
194 | 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, |
195 | 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, |
196 | 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, |
197 | 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, |
198 | 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, |
199 | 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, |
200 | 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, |
201 | 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, |
202 | 0x00000000, 0x00000002, 0x00000002, 0x0000001f, 0x00000000, |
203 | 0x00000000, 0x00000033, 0x00000002, 0x000004c2, 0x00000000, |
204 | 0x00000000, 0x00000000, 0x00000700, 0x00000000, 0x00000000, |
205 | 0x00000000, 0x40000000, 0x00000000, 0x00000000, 0x000fc78f, |
206 | 0x0000000f, 0x00000000, 0x00000000, 0x2a80001a, 0x05dc01e0, |
207 | 0x1f402710, 0x01f40000, 0x00001e00, 0x00000000, 0x00400000, |
208 | 0xffffffff, 0x0000ffff, 0x003f3f3f, 0x00000000, 0x00000000, |
209 | 0x00000000, 0x00000000, 0x00020000, 0x00020000, 0x00000001, |
210 | 0x00000052, 0x00000000, 0x00000168, 0x000100aa, 0x00003210, |
211 | 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, |
212 | 0x00000000, 0x00000000, 0xffffffff, 0x00000000, 0x00000000, |
213 | 0x32143320, 0xfaa4fa50, 0x00000100, 0x00000000, 0x00000000, |
214 | 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, |
215 | 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, |
216 | 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, |
217 | 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, |
218 | 0x00000000, 0x00100000, 0x0010f400, 0x00000100, 0x0001e800, |
219 | 0x00000000, 0x00000000, 0x00000000, 0x400000ff, 0x00080922, |
220 | 0x88a00010, 0x00000000, 0x40000000, 0x003e4180, 0x00000000, |
221 | 0x0000002c, 0x0000002c, 0x00000000, 0x00000000, 0x00000000, |
222 | 0x00000000, 0x00000040, 0x00000000, 0x00000000, 0x00000007, |
223 | 0x00000302, 0x00000e00, 0x00ff0000, 0x00000000, 0x000107ff, |
224 | 0x00481043, 0x00000000, 0xafa68e30, 0xfd14e000, 0x9c0a9f6b, |
225 | 0x00000000, 0x0000a000, 0x00000000, 0x00200400, 0x0040233c, |
226 | 0x0040233c, 0x00000044, 0x00000000, 0x00000000, 0x00000000, |
227 | 0x00000000, 0x01002310, 0x10000fff, 0x04900000, 0x04900000, |
228 | 0x00000001, 0x00000004, 0x1e1f2022, 0x0a0b0c0d, 0x00000000, |
229 | 0x9280c00a, 0x00020028, 0x5f3ca3de, 0x2108ecff, 0x14750604, |
230 | 0x004b6a8e, 0x190fb514, 0x00000000, 0x00000001, 0x00000000, |
231 | 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, |
232 | 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000001, |
233 | 0x201fff00, 0x006f0000, 0x03051000, 0x00000820, 0x06336f77, |
234 | 0x6af6532f, 0x08f186c8, 0x00046384, 0x00000000, 0x00000000, |
235 | 0x00000000, 0x00000000, 0xaaaaaaaa, 0x3c466478, 0x0cc80caa, |
236 | 0x00000000, 0x00001042, 0x803e4788, 0x4080a333, 0x40206c10, |
237 | 0x009c4060, 0x01834061, 0x00000400, 0x000003b5, 0x233f7180, |
238 | 0x20202020, 0x20202020, 0x38490a20, 0x00007bb6, 0x0fff3ffc, |
239 | 0x00000000, 0x00000000, 0x0cdbd380, 0x0f0f0f01, 0xdfa91f01, |
240 | 0x00000000, 0x0e79e5c6, 0x0e79e5c6, 0x00820820, 0x1ce739ce, |
241 | 0x07ffffef, 0x0fffffe7, 0x17ffffe5, 0x1fffffe4, 0x37ffffe3, |
242 | 0x3fffffe3, 0x57ffffe3, 0x5fffffe2, 0x7fffffe2, 0x7f3c7bba, |
243 | 0xf3307ff0, 0x20202020, 0x20202020, 0x1ce739ce, 0x000001ce, |
244 | 0x00000001, 0x00000000, 0x00000000, 0x00000000, 0x00000000, |
245 | 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, |
246 | 0x00000000, 0x00000246, 0x20202020, 0x20202020, 0x20202020, |
247 | 0x1ce739ce, 0x000001ce, 0x00000000, 0x18c43433, 0x00040000, |
248 | 0xdb005012, 0x04924914, 0x21084210, 0x6d801300, 0x07e41000, |
249 | 0x00040000, 0xdb005012, 0x04924914, 0x21084210, 0x6d801300, |
250 | 0x07e40000, 0x00100000, 0x773f0567, 0x54214514, 0x12035828, |
251 | 0x9259269a, 0x52802000, 0x0a8e370e, 0xc0102850, 0x812d4000, |
252 | 0x807ec400, 0x001b6db0, 0x00376b63, 0x06db6db6, 0x006d8000, |
253 | 0xffeffffe, 0xffeffffe, 0x00010000, 0x02060aeb, 0x2a850160 |
254 | }; |
255 | |
256 | static const uint16_t ar9280_2_0_fast_clock_regs[] = { |
257 | P(0x01030), P(0x01070), P(0x010b0), P(0x08014), P(0x0801c), |
258 | P(0x08318), P(0x09820), P(0x09824), P(0x09828), P(0x09834), |
259 | P(0x09844), P(0x09914), P(0x09918) |
260 | }; |
261 | |
262 | static const uint32_t ar9280_2_0_fast_clock_vals_5g20[] = { |
263 | 0x00000268, 0x0000018c, 0x00000fd0, 0x044c044c, 0x148ec02b, |
264 | 0x000044c0, 0x02020200, 0x01000f0f, 0x0b020001, 0x00000f0f, |
265 | 0x03721821, 0x00000898, 0x0000000b |
266 | }; |
267 | |
268 | #ifndef IEEE80211_NO_HT |
269 | static const uint32_t ar9280_2_0_fast_clock_vals_5g40[] = { |
270 | 0x000004d0, 0x00000318, 0x00001fa0, 0x08980898, 0x148ec057, |
271 | 0x00008980, 0x02020200, 0x01000f0f, 0x0b020001, 0x00000f0f, |
272 | 0x03721821, 0x00001130, 0x00000016 |
273 | }; |
274 | #endif |
275 | |
276 | static const struct athn_ini ar9280_2_0_ini = { |
277 | __arraycount(ar9280_2_0_regs), |
278 | ar9280_2_0_regs, |
279 | ar9280_2_0_vals_5g20, |
280 | #ifndef IEEE80211_NO_HT |
281 | ar9280_2_0_vals_5g40, |
282 | ar9280_2_0_vals_2g40, |
283 | #endif |
284 | ar9280_2_0_vals_2g20, |
285 | __arraycount(ar9280_2_0_cm_regs), |
286 | ar9280_2_0_cm_regs, |
287 | ar9280_2_0_cm_vals, |
288 | __arraycount(ar9280_2_0_fast_clock_regs), |
289 | ar9280_2_0_fast_clock_regs, |
290 | ar9280_2_0_fast_clock_vals_5g20, |
291 | #ifndef IEEE80211_NO_HT |
292 | ar9280_2_0_fast_clock_vals_5g40 |
293 | #endif |
294 | }; |
295 | |
296 | /* |
297 | * AR9280 2.0 Tx gains. |
298 | */ |
299 | static const uint16_t ar9280_2_0_tx_gain_regs[] = { |
300 | P(0x0a274), P(0x0a27c), P(0x0a300), P(0x0a304), P(0x0a308), |
301 | P(0x0a30c), P(0x0a310), P(0x0a314), P(0x0a318), P(0x0a31c), |
302 | P(0x0a320), P(0x0a324), P(0x0a328), P(0x0a32c), P(0x0a330), |
303 | P(0x0a334), P(0x0a338), P(0x0a33c), P(0x0a340), P(0x0a344), |
304 | P(0x0a348), P(0x0a34c), P(0x0a350), P(0x0a354), P(0x0a3ec), |
305 | P(0x07814), P(0x07838), P(0x0781c), P(0x07840), P(0x07820), |
306 | P(0x07844) |
307 | }; |
308 | |
309 | static const uint32_t ar9280_2_0_tx_gain_vals_5g[] = { |
310 | 0x0a19c652, 0x050701ce, 0x00000000, 0x00003002, 0x00006004, |
311 | 0x0000a006, 0x0000e012, 0x00011014, 0x0001504a, 0x0001904c, |
312 | 0x0001c04e, 0x00020092, 0x0002410a, 0x0002710c, 0x0002b18b, |
313 | 0x0002e1cc, 0x000321ec, 0x000321ec, 0x000321ec, 0x000321ec, |
314 | 0x000321ec, 0x000321ec, 0x000321ec, 0x000321ec, 0x00f70081, |
315 | 0x0019beff, 0x0019beff, 0x00392000, 0x00392000, 0x92592480, |
316 | 0x92592480 |
317 | }; |
318 | |
319 | static const uint32_t ar9280_2_0_tx_gain_vals_2g[] = { |
320 | 0x0a1aa652, 0x050701ce, 0x00000000, 0x00003002, 0x00008009, |
321 | 0x0000b00b, 0x0000e012, 0x00012048, 0x0001604a, 0x0001a211, |
322 | 0x0001e213, 0x0002121b, 0x00024412, 0x00028414, 0x0002b44a, |
323 | 0x00030649, 0x0003364b, 0x00038a49, 0x0003be48, 0x0003ee4a, |
324 | 0x00042e88, 0x00046e8a, 0x00049ec9, 0x0004bf42, 0x00f70081, |
325 | 0x0019beff, 0x0019beff, 0x00392000, 0x00392000, 0x92592480, |
326 | 0x92592480 |
327 | }; |
328 | |
329 | static const struct athn_gain ar9280_2_0_tx_gain = { |
330 | __arraycount(ar9280_2_0_tx_gain_regs), |
331 | ar9280_2_0_tx_gain_regs, |
332 | ar9280_2_0_tx_gain_vals_5g, |
333 | ar9280_2_0_tx_gain_vals_2g |
334 | }; |
335 | |
336 | static const uint32_t ar9280_2_0_tx_gain_high_power_vals_5g[] = { |
337 | 0x0a19e652, 0x050739ce, 0x00000000, 0x00003002, 0x00006004, |
338 | 0x0000a006, 0x0000e012, 0x00011014, 0x0001504a, 0x0001904c, |
339 | 0x0001c04e, 0x00021092, 0x0002510a, 0x0002910c, 0x0002c18b, |
340 | 0x0002f1cc, 0x000321eb, 0x000341ec, 0x000341ec, 0x000341ec, |
341 | 0x000341ec, 0x000341ec, 0x000341ec, 0x000341ec, 0x00f70081, |
342 | 0x00198eff, 0x00198eff, 0x00172000, 0x00172000, 0xf258a480, |
343 | 0xf258a480 |
344 | }; |
345 | |
346 | static const uint32_t ar9280_2_0_tx_gain_high_power_vals_2g[] = { |
347 | 0x0a1aa652, 0x050739ce, 0x00000000, 0x00004002, 0x00007008, |
348 | 0x0000c010, 0x00010012, 0x00013014, 0x0001820a, 0x0001b211, |
349 | 0x0001e213, 0x00022411, 0x00025413, 0x00029811, 0x0002c813, |
350 | 0x00030a14, 0x00035a50, 0x00039c4c, 0x0003de8a, 0x00042e92, |
351 | 0x00046ed2, 0x0004bed5, 0x0004ff54, 0x00055fd5, 0x00f70081, |
352 | 0x00198eff, 0x00198eff, 0x00172000, 0x00172000, 0xf258a480, |
353 | 0xf258a480 |
354 | }; |
355 | |
356 | static const struct athn_gain ar9280_2_0_tx_gain_high_power = { |
357 | __arraycount(ar9280_2_0_tx_gain_regs), |
358 | ar9280_2_0_tx_gain_regs, |
359 | ar9280_2_0_tx_gain_high_power_vals_5g, |
360 | ar9280_2_0_tx_gain_high_power_vals_2g |
361 | }; |
362 | |
363 | /* |
364 | * AR9280 2.0 Rx gains. |
365 | */ |
366 | static const uint16_t ar9280_2_0_rx_gain_regs[] = { |
367 | P(0x09a00), P(0x09a04), P(0x09a08), P(0x09a0c), P(0x09a10), |
368 | P(0x09a14), P(0x09a18), P(0x09a1c), P(0x09a20), P(0x09a24), |
369 | P(0x09a28), P(0x09a2c), P(0x09a30), P(0x09a34), P(0x09a38), |
370 | P(0x09a3c), P(0x09a40), P(0x09a44), P(0x09a48), P(0x09a4c), |
371 | P(0x09a50), P(0x09a54), P(0x09a58), P(0x09a5c), P(0x09a60), |
372 | P(0x09a64), P(0x09a68), P(0x09a6c), P(0x09a70), P(0x09a74), |
373 | P(0x09a78), P(0x09a7c), P(0x09a80), P(0x09a84), P(0x09a88), |
374 | P(0x09a8c), P(0x09a90), P(0x09a94), P(0x09a98), P(0x09a9c), |
375 | P(0x09aa0), P(0x09aa4), P(0x09aa8), P(0x09aac), P(0x09ab0), |
376 | P(0x09ab4), P(0x09ab8), P(0x09abc), P(0x09ac0), P(0x09ac4), |
377 | P(0x09ac8), P(0x09acc), P(0x09ad0), P(0x09ad4), P(0x09ad8), |
378 | P(0x09adc), P(0x09ae0), P(0x09ae4), P(0x09ae8), P(0x09aec), |
379 | P(0x09af0), P(0x09af4), P(0x09af8), P(0x09afc), P(0x09b00), |
380 | P(0x09b04), P(0x09b08), P(0x09b0c), P(0x09b10), P(0x09b14), |
381 | P(0x09b18), P(0x09b1c), P(0x09b20), P(0x09b24), P(0x09b28), |
382 | P(0x09b2c), P(0x09b30), P(0x09b34), P(0x09b38), P(0x09b3c), |
383 | P(0x09b40), P(0x09b44), P(0x09b48), P(0x09b4c), P(0x09b50), |
384 | P(0x09b54), P(0x09b58), P(0x09b5c), P(0x09b60), P(0x09b64), |
385 | P(0x09b68), P(0x09b6c), P(0x09b70), P(0x09b74), P(0x09b78), |
386 | P(0x09b7c), P(0x09b80), P(0x09b84), P(0x09b88), P(0x09b8c), |
387 | P(0x09b90), P(0x09b94), P(0x09b98), P(0x09b9c), P(0x09ba0), |
388 | P(0x09ba4), P(0x09ba8), P(0x09bac), P(0x09bb0), P(0x09bb4), |
389 | P(0x09bb8), P(0x09bbc), P(0x09bc0), P(0x09bc4), P(0x09bc8), |
390 | P(0x09bcc), P(0x09bd0), P(0x09bd4), P(0x09bd8), P(0x09bdc), |
391 | P(0x09be0), P(0x09be4), P(0x09be8), P(0x09bec), P(0x09bf0), |
392 | P(0x09bf4), P(0x09bf8), P(0x09bfc), P(0x09848), P(0x0a848) |
393 | }; |
394 | |
395 | static const uint32_t ar9280_2_0_rx_gain_vals_5g[] = { |
396 | 0x00008184, 0x00008188, 0x0000818c, 0x00008190, 0x00008194, |
397 | 0x00008200, 0x00008204, 0x00008208, 0x0000820c, 0x00008210, |
398 | 0x00008214, 0x00008280, 0x00008284, 0x00008288, 0x0000828c, |
399 | 0x00008290, 0x00008300, 0x00008304, 0x00008308, 0x0000830c, |
400 | 0x00008310, 0x00008314, 0x00008380, 0x00008384, 0x00008388, |
401 | 0x0000838c, 0x00008390, 0x00008394, 0x0000a380, 0x0000a384, |
402 | 0x0000a388, 0x0000a38c, 0x0000a390, 0x0000a394, 0x0000a780, |
403 | 0x0000a784, 0x0000a788, 0x0000a78c, 0x0000a790, 0x0000a794, |
404 | 0x0000ab84, 0x0000ab88, 0x0000ab8c, 0x0000ab90, 0x0000ab94, |
405 | 0x0000af80, 0x0000af84, 0x0000af88, 0x0000af8c, 0x0000af90, |
406 | 0x0000af94, 0x0000b380, 0x0000b384, 0x0000b388, 0x0000b38c, |
407 | 0x0000b390, 0x0000b394, 0x0000b398, 0x0000b780, 0x0000b784, |
408 | 0x0000b788, 0x0000b78c, 0x0000b790, 0x0000b794, 0x0000b798, |
409 | 0x0000d784, 0x0000d788, 0x0000d78c, 0x0000d790, 0x0000f780, |
410 | 0x0000f784, 0x0000f788, 0x0000f78c, 0x0000f790, 0x0000f794, |
411 | 0x0000f7a4, 0x0000f7a8, 0x0000f7ac, 0x0000f7b0, 0x0000f7b4, |
412 | 0x0000f7a1, 0x0000f7a5, 0x0000f7a9, 0x0000f7ad, 0x0000f7b1, |
413 | 0x0000f7b5, 0x0000f7c5, 0x0000f7c9, 0x0000f7cd, 0x0000f7d1, |
414 | 0x0000f7d5, 0x0000f7c2, 0x0000f7c6, 0x0000f7ca, 0x0000f7ce, |
415 | 0x0000f7d2, 0x0000f7d6, 0x0000f7c3, 0x0000f7c7, 0x0000f7cb, |
416 | 0x0000f7d3, 0x0000f7d7, 0x0000f7db, 0x0000f7db, 0x0000f7db, |
417 | 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, |
418 | 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, |
419 | 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, |
420 | 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, |
421 | 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x00001066, 0x00001066 |
422 | }; |
423 | |
424 | static const uint32_t ar9280_2_0_rx_gain_vals_2g[] = { |
425 | 0x00008000, 0x00008000, 0x00008000, 0x00008000, 0x00008000, |
426 | 0x00008000, 0x00008004, 0x00008008, 0x0000800c, 0x00008080, |
427 | 0x00008084, 0x00008088, 0x0000808c, 0x00008100, 0x00008104, |
428 | 0x00008108, 0x0000810c, 0x00008110, 0x00008114, 0x00008180, |
429 | 0x00008184, 0x00008188, 0x0000818c, 0x00008190, 0x00008194, |
430 | 0x000081a0, 0x0000820c, 0x000081a8, 0x00008284, 0x00008288, |
431 | 0x00008224, 0x00008290, 0x00008300, 0x00008304, 0x00008308, |
432 | 0x0000830c, 0x00008380, 0x00008384, 0x00008700, 0x00008704, |
433 | 0x00008708, 0x0000870c, 0x00008780, 0x00008784, 0x00008b00, |
434 | 0x00008b04, 0x00008b08, 0x00008b0c, 0x00008b80, 0x00008b84, |
435 | 0x00008b88, 0x00008b8c, 0x00008b90, 0x00008f80, 0x00008f84, |
436 | 0x00008f88, 0x00008f8c, 0x00008f90, 0x0000930c, 0x00009310, |
437 | 0x00009384, 0x00009388, 0x00009324, 0x00009704, 0x000096a4, |
438 | 0x000096a8, 0x00009710, 0x00009714, 0x00009720, 0x00009724, |
439 | 0x00009728, 0x0000972c, 0x000097a0, 0x000097a4, 0x000097a8, |
440 | 0x000097b0, 0x000097b4, 0x000097b8, 0x000097a5, 0x000097a9, |
441 | 0x000097ad, 0x000097b1, 0x000097b5, 0x000097b9, 0x000097c5, |
442 | 0x000097c9, 0x000097d1, 0x000097d5, 0x000097d9, 0x000097c6, |
443 | 0x000097ca, 0x000097ce, 0x000097d2, 0x000097d6, 0x000097c3, |
444 | 0x000097c7, 0x000097cb, 0x000097cf, 0x000097d7, 0x000097db, |
445 | 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, |
446 | 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, |
447 | 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, |
448 | 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, |
449 | 0x000097db, 0x000097db, 0x000097db, 0x000097db, 0x000097db, |
450 | 0x000097db, 0x000097db, 0x000097db, 0x00001063, 0x00001063 |
451 | }; |
452 | |
453 | static const struct athn_gain ar9280_2_0_rx_gain = { |
454 | __arraycount(ar9280_2_0_rx_gain_regs), |
455 | ar9280_2_0_rx_gain_regs, |
456 | ar9280_2_0_rx_gain_vals_5g, |
457 | ar9280_2_0_rx_gain_vals_2g |
458 | }; |
459 | |
460 | static const uint32_t ar9280_2_0_rx_gain_13db_backoff_vals_5g[] = { |
461 | 0x00008184, 0x00008188, 0x0000818c, 0x00008190, 0x00008194, |
462 | 0x00008200, 0x00008204, 0x00008208, 0x0000820c, 0x00008210, |
463 | 0x00008214, 0x00008280, 0x00008284, 0x00008288, 0x0000828c, |
464 | 0x00008290, 0x00008300, 0x00008304, 0x00008308, 0x0000830c, |
465 | 0x00008310, 0x00008314, 0x00008380, 0x00008384, 0x00008388, |
466 | 0x0000838c, 0x00008390, 0x00008394, 0x0000a380, 0x0000a384, |
467 | 0x0000a388, 0x0000a38c, 0x0000a390, 0x0000a394, 0x0000a780, |
468 | 0x0000a784, 0x0000a788, 0x0000a78c, 0x0000a790, 0x0000a794, |
469 | 0x0000ab84, 0x0000ab88, 0x0000ab8c, 0x0000ab90, 0x0000ab94, |
470 | 0x0000af80, 0x0000af84, 0x0000af88, 0x0000af8c, 0x0000af90, |
471 | 0x0000af94, 0x0000b380, 0x0000b384, 0x0000b388, 0x0000b38c, |
472 | 0x0000b390, 0x0000b394, 0x0000b398, 0x0000b780, 0x0000b784, |
473 | 0x0000b788, 0x0000b78c, 0x0000b790, 0x0000b794, 0x0000b798, |
474 | 0x0000d784, 0x0000d788, 0x0000d78c, 0x0000d790, 0x0000f780, |
475 | 0x0000f784, 0x0000f788, 0x0000f78c, 0x0000f790, 0x0000f794, |
476 | 0x0000f7a4, 0x0000f7a8, 0x0000f7ac, 0x0000f7b0, 0x0000f7b4, |
477 | 0x0000f7a1, 0x0000f7a5, 0x0000f7a9, 0x0000f7ad, 0x0000f7b1, |
478 | 0x0000f7b5, 0x0000f7c5, 0x0000f7c9, 0x0000f7cd, 0x0000f7d1, |
479 | 0x0000f7d5, 0x0000f7c2, 0x0000f7c6, 0x0000f7ca, 0x0000f7ce, |
480 | 0x0000f7d2, 0x0000f7d6, 0x0000f7c3, 0x0000f7c7, 0x0000f7cb, |
481 | 0x0000f7d3, 0x0000f7d7, 0x0000f7db, 0x0000f7db, 0x0000f7db, |
482 | 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, |
483 | 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, |
484 | 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, |
485 | 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, |
486 | 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x00001066, 0x00001066 |
487 | }; |
488 | |
489 | static const uint32_t ar9280_2_0_rx_gain_13db_backoff_vals_2g[] = { |
490 | 0x00000290, 0x00000300, 0x00000304, 0x00000308, 0x0000030c, |
491 | 0x00008000, 0x00008004, 0x00008008, 0x0000800c, 0x00008080, |
492 | 0x00008084, 0x00008088, 0x0000808c, 0x00008100, 0x00008104, |
493 | 0x00008108, 0x0000810c, 0x00008110, 0x00008114, 0x00008180, |
494 | 0x00008184, 0x00008188, 0x0000818c, 0x00008190, 0x00008194, |
495 | 0x000081a0, 0x0000820c, 0x000081a8, 0x00008284, 0x00008288, |
496 | 0x00008224, 0x00008290, 0x00008300, 0x00008304, 0x00008308, |
497 | 0x0000830c, 0x00008380, 0x00008384, 0x00008700, 0x00008704, |
498 | 0x00008708, 0x0000870c, 0x00008780, 0x00008784, 0x00008b00, |
499 | 0x00008b04, 0x00008b08, 0x00008b0c, 0x00008b80, 0x00008b84, |
500 | 0x00008b88, 0x00008b8c, 0x00008b90, 0x00008f80, 0x00008f84, |
501 | 0x00008f88, 0x00008f8c, 0x00008f90, 0x00009310, 0x00009314, |
502 | 0x00009320, 0x00009324, 0x00009328, 0x0000932c, 0x00009330, |
503 | 0x00009334, 0x00009321, 0x00009325, 0x00009329, 0x0000932d, |
504 | 0x00009331, 0x00009335, 0x00009322, 0x00009326, 0x0000932a, |
505 | 0x0000932e, 0x00009332, 0x00009336, 0x00009323, 0x00009327, |
506 | 0x0000932b, 0x0000932f, 0x00009333, 0x00009337, 0x00009343, |
507 | 0x00009347, 0x0000934b, 0x0000934f, 0x00009353, 0x00009357, |
508 | 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, |
509 | 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, |
510 | 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, |
511 | 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, |
512 | 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, |
513 | 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, |
514 | 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, 0x0000935b, |
515 | 0x0000935b, 0x0000935b, 0x0000935b, 0x0000105a, 0x0000105a |
516 | }; |
517 | |
518 | static const struct athn_gain ar9280_2_0_rx_gain_13db_backoff = { |
519 | __arraycount(ar9280_2_0_rx_gain_regs), |
520 | ar9280_2_0_rx_gain_regs, |
521 | ar9280_2_0_rx_gain_13db_backoff_vals_5g, |
522 | ar9280_2_0_rx_gain_13db_backoff_vals_2g |
523 | }; |
524 | |
525 | static const uint32_t ar9280_2_0_rx_gain_23db_backoff_vals_5g[] = { |
526 | 0x00008184, 0x00008188, 0x0000818c, 0x00008190, 0x00008194, |
527 | 0x00008200, 0x00008204, 0x00008208, 0x0000820c, 0x00008210, |
528 | 0x00008214, 0x00008280, 0x00008284, 0x00008288, 0x0000828c, |
529 | 0x00008290, 0x00008300, 0x00008304, 0x00008308, 0x0000830c, |
530 | 0x00008310, 0x00008314, 0x00008380, 0x00008384, 0x00008388, |
531 | 0x0000838c, 0x00008390, 0x00008394, 0x0000a380, 0x0000a384, |
532 | 0x0000a388, 0x0000a38c, 0x0000a390, 0x0000a394, 0x0000a780, |
533 | 0x0000a784, 0x0000a788, 0x0000a78c, 0x0000a790, 0x0000a794, |
534 | 0x0000ab84, 0x0000ab88, 0x0000ab8c, 0x0000ab90, 0x0000ab94, |
535 | 0x0000af80, 0x0000af84, 0x0000af88, 0x0000af8c, 0x0000af90, |
536 | 0x0000af94, 0x0000b380, 0x0000b384, 0x0000b388, 0x0000b38c, |
537 | 0x0000b390, 0x0000b394, 0x0000b398, 0x0000b780, 0x0000b784, |
538 | 0x0000b788, 0x0000b78c, 0x0000b790, 0x0000b794, 0x0000b798, |
539 | 0x0000d784, 0x0000d788, 0x0000d78c, 0x0000d790, 0x0000f780, |
540 | 0x0000f784, 0x0000f788, 0x0000f78c, 0x0000f790, 0x0000f794, |
541 | 0x0000f7a4, 0x0000f7a8, 0x0000f7ac, 0x0000f7b0, 0x0000f7b4, |
542 | 0x0000f7a1, 0x0000f7a5, 0x0000f7a9, 0x0000f7ad, 0x0000f7b1, |
543 | 0x0000f7b5, 0x0000f7c5, 0x0000f7c9, 0x0000f7cd, 0x0000f7d1, |
544 | 0x0000f7d5, 0x0000f7c2, 0x0000f7c6, 0x0000f7ca, 0x0000f7ce, |
545 | 0x0000f7d2, 0x0000f7d6, 0x0000f7c3, 0x0000f7c7, 0x0000f7cb, |
546 | 0x0000f7d3, 0x0000f7d7, 0x0000f7db, 0x0000f7db, 0x0000f7db, |
547 | 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, |
548 | 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, |
549 | 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, |
550 | 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x0000f7db, |
551 | 0x0000f7db, 0x0000f7db, 0x0000f7db, 0x00001066, 0x00001066 |
552 | }; |
553 | |
554 | static const uint32_t ar9280_2_0_rx_gain_23db_backoff_vals_2g[] = { |
555 | 0x00000290, 0x00000300, 0x00000304, 0x00000308, 0x0000030c, |
556 | 0x00008000, 0x00008004, 0x00008008, 0x0000800c, 0x00008080, |
557 | 0x00008084, 0x00008088, 0x0000808c, 0x00008100, 0x00008104, |
558 | 0x00008108, 0x0000810c, 0x00008110, 0x00008114, 0x00008180, |
559 | 0x00008184, 0x00008188, 0x0000818c, 0x00008190, 0x00008194, |
560 | 0x000081a0, 0x0000820c, 0x000081a8, 0x00008284, 0x00008288, |
561 | 0x00008224, 0x00008290, 0x00008300, 0x00008304, 0x00008308, |
562 | 0x0000830c, 0x00008380, 0x00008384, 0x00008700, 0x00008704, |
563 | 0x00008708, 0x0000870c, 0x00008780, 0x00008784, 0x00008b00, |
564 | 0x00008b04, 0x00008b08, 0x00008b0c, 0x00008b10, 0x00008b80, |
565 | 0x00008b84, 0x00008b88, 0x00008b8c, 0x00008b90, 0x00008b94, |
566 | 0x00008b98, 0x00008ba4, 0x00008ba8, 0x00008bac, 0x00008bb0, |
567 | 0x00008bb4, 0x00008ba1, 0x00008ba5, 0x00008ba9, 0x00008bad, |
568 | 0x00008bb1, 0x00008bb5, 0x00008ba2, 0x00008ba6, 0x00008baa, |
569 | 0x00008bae, 0x00008bb2, 0x00008bb6, 0x00008ba3, 0x00008ba7, |
570 | 0x00008bab, 0x00008baf, 0x00008bb3, 0x00008bb7, 0x00008bc3, |
571 | 0x00008bc7, 0x00008bcb, 0x00008bcf, 0x00008bd3, 0x00008bd7, |
572 | 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, |
573 | 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, |
574 | 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, |
575 | 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, |
576 | 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, |
577 | 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, |
578 | 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, |
579 | 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00008bdb, |
580 | 0x00008bdb, 0x00008bdb, 0x00008bdb, 0x00001055, 0x00001055 |
581 | }; |
582 | |
583 | static const struct athn_gain ar9280_2_0_rx_gain_23db_backoff = { |
584 | __arraycount(ar9280_2_0_rx_gain_regs), |
585 | ar9280_2_0_rx_gain_regs, |
586 | ar9280_2_0_rx_gain_23db_backoff_vals_5g, |
587 | ar9280_2_0_rx_gain_23db_backoff_vals_2g |
588 | }; |
589 | |
590 | /* |
591 | * Serializer/Deserializer programming. |
592 | */ |
593 | |
594 | static const uint32_t ar9280_2_0_serdes_regs[] = { |
595 | AR_PCIE_SERDES, |
596 | AR_PCIE_SERDES, |
597 | AR_PCIE_SERDES, |
598 | AR_PCIE_SERDES, |
599 | AR_PCIE_SERDES, |
600 | AR_PCIE_SERDES, |
601 | AR_PCIE_SERDES, |
602 | AR_PCIE_SERDES, |
603 | AR_PCIE_SERDES, |
604 | AR_PCIE_SERDES2, |
605 | }; |
606 | |
607 | static const uint32_t ar9280_2_0_serdes_vals[] = { |
608 | 0x9248fd00, |
609 | 0x24924924, |
610 | 0xa8000019, |
611 | 0x13160820, |
612 | 0xe5980560, |
613 | #ifdef ATHN_PCIE_CLKREQ |
614 | 0xc01dcffc, |
615 | #else |
616 | 0xc01dcffd, |
617 | #endif |
618 | 0x1aaabe41, |
619 | 0xbe105554, |
620 | 0x00043007, |
621 | 0x00000000 |
622 | }; |
623 | |
624 | static const struct athn_serdes ar9280_2_0_serdes = { |
625 | __arraycount(ar9280_2_0_serdes_vals), |
626 | ar9280_2_0_serdes_regs, |
627 | ar9280_2_0_serdes_vals |
628 | }; |
629 | |
630 | #endif /* _ARN9280REG_H_ */ |
631 | |