xref: /freebsd/sys/dev/iwn/if_iwn_chip_cfg.h (revision 6ae1554a5d9b318f8ad53ccc39fa5a961403da73)
1 /*-
2  * Copyright (c) 2013 Cedric GROSS <cg@cgross.info>
3  * Copyright (c) 2011 Intel Corporation
4  *
5  * Permission to use, copy, modify, and distribute this software for any
6  * purpose with or without fee is hereby granted, provided that the above
7  * copyright notice and this permission notice appear in all copies.
8  *
9  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
10  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
11  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
12  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
13  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
14  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
15  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
16  *
17  * $FreeBSD$
18  */
19 
20 #ifndef	__IF_IWN_CHIP_CFG_H__
21 #define	__IF_IWN_CHIP_CFG_H__
22 
23 /* ==========================================================================
24  *                                  NIC PARAMETERS
25  *
26  * ==========================================================================
27  */
28 
29 /*
30  * Flags for managing calibration result. See calib_need
31  * in iwn_base_params struct
32  *
33  * These are bitmasks that determine which indexes in the calibcmd
34  * array are pushed up.
35  */
36 #define IWN_FLG_NEED_PHY_CALIB_DC		(1<<0)
37 #define IWN_FLG_NEED_PHY_CALIB_LO		(1<<1)
38 #define IWN_FLG_NEED_PHY_CALIB_TX_IQ		(1<<2)
39 #define IWN_FLG_NEED_PHY_CALIB_TX_IQ_PERIODIC	(1<<3)
40 #define IWN_FLG_NEED_PHY_CALIB_BASE_BAND	(1<<4)
41 /*
42  * These aren't (yet) included in the calibcmd array, but
43  * are used as flags for which calibrations to use.
44  *
45  * XXX I think they should be named differently and
46  * stuffed in a different member in the config struct!
47  */
48 #define IWN_FLG_NEED_PHY_CALIB_TEMP_OFFSET	(1<<5)
49 #define IWN_FLG_NEED_PHY_CALIB_CRYSTAL		(1<<6)
50 #define IWN_FLG_NEED_PHY_CALIB_TEMP_OFFSETv2	(1<<7)
51 
52 /*
53  * Each chip has a different threshold for PLCP errors that should trigger a
54  * retune.
55  */
56 #define	IWN_PLCP_ERR_DEFAULT_THRESHOLD		50
57 #define	IWN_PLCP_ERR_LONG_THRESHOLD		100
58 #define	IWN_PLCP_ERR_EXT_LONG_THRESHOLD		200
59 
60 /*
61  * Define some parameters for managing different NIC.
62  * Refer to linux specific file like iwl-xxxx.c to determine correct value
63  * for NIC.
64  *
65  * @max_ll_items: max number of OTP blocks
66  * @shadow_ram_support: shadow support for OTP memory
67  * @shadow_reg_enable: HW shadhow register bit
68  * @no_idle_support: do not support idle mode
69  * @advanced_bt_coexist : Advanced BT management
70  * @bt_session_2 : NIC need a new struct for configure BT coexistence. Needed
71  *   only if advanced_bt_coexist is true
72  * @bt_sco_disable :
73  * @additional_nic_config: For 6005 series
74  * @iq_invert : ? But need it for N 2000 series
75  * @regulatory_bands : XXX
76  * @enhanced_TX_power : EEPROM Has advanced TX power options. Set 'True'
77  *    if update_enhanced_txpower = iwl_eeprom_enhanced_txpower.
78  *    See iwl-agn-devices.c file to determine that(enhanced_txpower)
79  * @need_temp_offset_calib : Need to compute some temp offset for calibration.
80  * @calib_need : Use IWN_FLG_NEED_PHY_CALIB_* flags to specify which
81  *    calibration data ucode need. See calib_init_cfg in iwl-xxxx.c
82  *    linux kernel file
83  * @support_hostap: Define IEEE80211_C_HOSTAP for ic_caps
84  * @no_multi_vaps: See iwn_vap_create
85  * @additional_gp_drv_bit : Specific bit to defined during nic_config
86  * @bt_mode: BT configuration mode
87  */
88 enum bt_mode_enum {
89 	IWN_BT_NONE,
90 	IWN_BT_SIMPLE,
91 	IWN_BT_ADVANCED
92 };
93 
94 struct iwn_base_params {
95 	uint32_t	pll_cfg_val;
96 	const uint16_t	max_ll_items;
97 #define IWN_OTP_MAX_LL_ITEMS_1000		(3)	/* OTP blocks for 1000 */
98 #define IWN_OTP_MAX_LL_ITEMS_6x00		(4)	/* OTP blocks for 6x00 */
99 #define IWN_OTP_MAX_LL_ITEMS_6x50		(7)	/* OTP blocks for 6x50 */
100 #define IWN_OTP_MAX_LL_ITEMS_2x00		(4)	/* OTP blocks for 2x00 */
101 	const bool	shadow_ram_support;
102 	const bool	shadow_reg_enable;
103 	const bool	bt_session_2;
104 	const bool	bt_sco_disable;
105 	const bool	additional_nic_config;
106 	const uint32_t	*regulatory_bands;
107 	const bool	enhanced_TX_power;
108 	const uint16_t	calib_need;
109 	const bool	support_hostap;
110 	const bool	no_multi_vaps;
111 	uint8_t	additional_gp_drv_bit;
112 	enum bt_mode_enum	bt_mode;
113 	uint32_t	plcp_err_threshold;
114 };
115 
116 static const struct iwn_base_params iwn5000_base_params = {
117 	.pll_cfg_val = IWN_ANA_PLL_INIT,	/* pll_cfg_val; */
118 	.max_ll_items = IWN_OTP_MAX_LL_ITEMS_6x00,	/* max_ll_items */
119 	.shadow_ram_support = false,	/* shadow_ram_support */
120 	.shadow_reg_enable = false,	/* shadow_reg_enable */
121 	.bt_session_2 = false,	/* bt_session_2 */
122 	.bt_sco_disable = true,	/* bt_sco_disable */
123 	.additional_nic_config = false,	/* additional_nic_config */
124 	.regulatory_bands = iwn5000_regulatory_bands,	/* regulatory_bands */
125 	.enhanced_TX_power = false,	/* enhanced_TX_power */
126 	.calib_need =
127 	    ( IWN_FLG_NEED_PHY_CALIB_LO
128 	    | IWN_FLG_NEED_PHY_CALIB_TX_IQ_PERIODIC
129 	    | IWN_FLG_NEED_PHY_CALIB_TX_IQ
130 	    | IWN_FLG_NEED_PHY_CALIB_BASE_BAND ),
131 	.support_hostap = false,	/* support_hostap */
132 	.no_multi_vaps = true,	/* no_multi_vaps */
133 	.additional_gp_drv_bit = IWN_GP_DRIVER_NONE,	/* additional_gp_drv_bit */
134 	.bt_mode = IWN_BT_NONE,	/* bt_mode */
135 	.plcp_err_threshold = IWN_PLCP_ERR_LONG_THRESHOLD,
136 };
137 
138 /*
139  * 4965 support
140  */
141 static const struct iwn_base_params iwn4965_base_params = {
142 	.pll_cfg_val = 0,				/* pll_cfg_val; */
143 	.max_ll_items = IWN_OTP_MAX_LL_ITEMS_6x00,	/* max_ll_items - ignored for 4965 */
144 	.shadow_ram_support = true,	/* shadow_ram_support */
145 	.shadow_reg_enable = false,	/* shadow_reg_enable */
146 	.bt_session_2 = false,	/* bt_session_2 XXX unknown? */
147 	.bt_sco_disable = true,	/* bt_sco_disable XXX unknown? */
148 	.additional_nic_config = false,	/* additional_nic_config - not for 4965 */
149 	.regulatory_bands = iwn5000_regulatory_bands,	/* regulatory_bands */
150 	.enhanced_TX_power = false,	/* enhanced_TX_power - not for 4965 */
151 	.calib_need =
152 	    (IWN_FLG_NEED_PHY_CALIB_DC
153 	    | IWN_FLG_NEED_PHY_CALIB_LO
154 	    | IWN_FLG_NEED_PHY_CALIB_TX_IQ_PERIODIC
155 	    | IWN_FLG_NEED_PHY_CALIB_TX_IQ
156 	    | IWN_FLG_NEED_PHY_CALIB_BASE_BAND ),
157 	.support_hostap = false,	/* support_hostap - XXX should work on fixing! */
158 	.no_multi_vaps = true,	/* no_multi_vaps - XXX should work on fixing!  */
159 	.additional_gp_drv_bit = IWN_GP_DRIVER_NONE,	/* additional_gp_drv_bit */
160 	.bt_mode = IWN_BT_SIMPLE,	/* bt_mode */
161 	.plcp_err_threshold = IWN_PLCP_ERR_DEFAULT_THRESHOLD,
162 };
163 
164 
165 static const struct iwn_base_params iwn2000_base_params = {
166 	.pll_cfg_val = 0,
167 	.max_ll_items = IWN_OTP_MAX_LL_ITEMS_2x00,
168 	.shadow_ram_support = true,
169 	.shadow_reg_enable = false,
170 	.bt_session_2 = false,
171 	.bt_sco_disable = true,
172 	.additional_nic_config = false,
173 	.regulatory_bands = iwn2030_regulatory_bands,
174 	.enhanced_TX_power = true,
175 	.calib_need =
176 	    (IWN_FLG_NEED_PHY_CALIB_DC
177 	    | IWN_FLG_NEED_PHY_CALIB_LO
178 	    | IWN_FLG_NEED_PHY_CALIB_TX_IQ
179 	    | IWN_FLG_NEED_PHY_CALIB_BASE_BAND
180 	    | IWN_FLG_NEED_PHY_CALIB_TEMP_OFFSETv2 ),
181 	.support_hostap = true,
182 	.no_multi_vaps = false,
183 	.additional_gp_drv_bit = IWN_GP_DRIVER_REG_BIT_RADIO_IQ_INVERT,
184 	.bt_mode = IWN_BT_NONE,
185 	.plcp_err_threshold = IWN_PLCP_ERR_DEFAULT_THRESHOLD,
186 };
187 
188 static const struct iwn_base_params iwn2030_base_params = {
189 	.pll_cfg_val = 0,
190 	.max_ll_items = IWN_OTP_MAX_LL_ITEMS_2x00,
191 	.shadow_ram_support = true,
192 	.shadow_reg_enable = false,     /* XXX check? */
193 	.bt_session_2 = true,
194 	.bt_sco_disable = true,
195 	.additional_nic_config = false,
196 	.regulatory_bands = iwn2030_regulatory_bands,
197 	.enhanced_TX_power = true,
198 	.calib_need =
199 	    (IWN_FLG_NEED_PHY_CALIB_DC
200 	    | IWN_FLG_NEED_PHY_CALIB_LO
201 	    | IWN_FLG_NEED_PHY_CALIB_TX_IQ
202 	    | IWN_FLG_NEED_PHY_CALIB_BASE_BAND
203 	    | IWN_FLG_NEED_PHY_CALIB_TEMP_OFFSETv2 ),
204 	.support_hostap = true,
205 	.no_multi_vaps = false,
206 	.additional_gp_drv_bit = IWN_GP_DRIVER_REG_BIT_RADIO_IQ_INVERT,
207 	.bt_mode = IWN_BT_ADVANCED,
208 	.plcp_err_threshold = IWN_PLCP_ERR_DEFAULT_THRESHOLD,
209 };
210 
211 static const struct iwn_base_params iwn1000_base_params = {
212 	.pll_cfg_val = IWN_ANA_PLL_INIT,
213 	.max_ll_items = IWN_OTP_MAX_LL_ITEMS_1000,
214 	.shadow_ram_support = false,
215 	.shadow_reg_enable = false,	/* XXX check? */
216 	.bt_session_2 = false,
217 	.bt_sco_disable = false,
218 	.additional_nic_config = false,
219 	.regulatory_bands = iwn5000_regulatory_bands,
220 	.enhanced_TX_power = false,
221 	.calib_need =
222 	    ( IWN_FLG_NEED_PHY_CALIB_LO
223 	    | IWN_FLG_NEED_PHY_CALIB_TX_IQ_PERIODIC
224 	    | IWN_FLG_NEED_PHY_CALIB_TX_IQ
225 	    | IWN_FLG_NEED_PHY_CALIB_BASE_BAND
226 	    ),
227 	.support_hostap = false,
228 	.no_multi_vaps = true,
229 	.additional_gp_drv_bit = IWN_GP_DRIVER_NONE,
230 	/* XXX 1000 - no BT */
231 	.bt_mode = IWN_BT_SIMPLE,
232 	.plcp_err_threshold = IWN_PLCP_ERR_EXT_LONG_THRESHOLD,
233 };
234 static const struct iwn_base_params iwn_6000_base_params = {
235 	.pll_cfg_val = 0,
236 	.max_ll_items = IWN_OTP_MAX_LL_ITEMS_6x00,
237 	.shadow_ram_support = true,
238 	.shadow_reg_enable = true,
239 	.bt_session_2 = false,
240 	.bt_sco_disable = false,
241 	.additional_nic_config = false,
242 	.regulatory_bands = iwn6000_regulatory_bands,
243 	.enhanced_TX_power = true,
244 	.calib_need =
245 	    (IWN_FLG_NEED_PHY_CALIB_DC
246 	    | IWN_FLG_NEED_PHY_CALIB_LO
247 	    | IWN_FLG_NEED_PHY_CALIB_TX_IQ
248 	    | IWN_FLG_NEED_PHY_CALIB_BASE_BAND ),
249 	.support_hostap = false,
250 	.no_multi_vaps = true,
251 	.additional_gp_drv_bit = IWN_GP_DRIVER_NONE,
252 	.bt_mode = IWN_BT_SIMPLE,
253 	.plcp_err_threshold = IWN_PLCP_ERR_DEFAULT_THRESHOLD,
254 };
255 static const struct iwn_base_params iwn_6000i_base_params = {
256 	.pll_cfg_val = 0,
257 	.max_ll_items = IWN_OTP_MAX_LL_ITEMS_6x00,
258 	.shadow_ram_support = true,
259 	.shadow_reg_enable = true,
260 	.bt_session_2 = false,
261 	.bt_sco_disable = true,
262 	.additional_nic_config = false,
263 	.regulatory_bands = iwn6000_regulatory_bands,
264 	.enhanced_TX_power = true,
265 	.calib_need =
266 	    (IWN_FLG_NEED_PHY_CALIB_DC
267 	    | IWN_FLG_NEED_PHY_CALIB_LO
268 	    | IWN_FLG_NEED_PHY_CALIB_TX_IQ
269 	    | IWN_FLG_NEED_PHY_CALIB_BASE_BAND ),
270 	.support_hostap = false,
271 	.no_multi_vaps = true,
272 	.additional_gp_drv_bit = IWN_GP_DRIVER_NONE,
273 	.bt_mode = IWN_BT_SIMPLE,
274 	.plcp_err_threshold = IWN_PLCP_ERR_DEFAULT_THRESHOLD,
275 };
276 static const struct iwn_base_params iwn_6000g2_base_params = {
277 	.pll_cfg_val = 0,
278 	.max_ll_items = IWN_OTP_MAX_LL_ITEMS_6x00,
279 	.shadow_ram_support = true,
280 	.shadow_reg_enable = true,
281 	.bt_session_2 = false,
282 	.bt_sco_disable = true,
283 	.additional_nic_config = false,
284 	.regulatory_bands = iwn6000_regulatory_bands,
285 	.enhanced_TX_power = true,
286 	.calib_need =
287 	    (IWN_FLG_NEED_PHY_CALIB_DC
288 	    | IWN_FLG_NEED_PHY_CALIB_LO
289 	    | IWN_FLG_NEED_PHY_CALIB_TX_IQ
290 	    | IWN_FLG_NEED_PHY_CALIB_BASE_BAND
291 	    | IWN_FLG_NEED_PHY_CALIB_TEMP_OFFSET ),
292 	.support_hostap = false,
293 	.no_multi_vaps = true,
294 	.additional_gp_drv_bit = 0,
295 	.bt_mode = IWN_BT_SIMPLE,
296 	.plcp_err_threshold = IWN_PLCP_ERR_DEFAULT_THRESHOLD,
297 };
298 
299 static const struct iwn_base_params iwn_6050_base_params = {
300 	.pll_cfg_val = 0,
301 	.max_ll_items = IWN_OTP_MAX_LL_ITEMS_6x50,
302 	.shadow_ram_support = true,
303 	.shadow_reg_enable = true,
304 	.bt_session_2 = false,
305 	.bt_sco_disable = true,
306 	.additional_nic_config = true,
307 	.regulatory_bands = iwn6000_regulatory_bands,
308 	.enhanced_TX_power = true,
309 	.calib_need =
310 	    (IWN_FLG_NEED_PHY_CALIB_LO
311 	    | IWN_FLG_NEED_PHY_CALIB_TX_IQ
312 	    | IWN_FLG_NEED_PHY_CALIB_BASE_BAND ),
313 	.support_hostap = false,
314 	.no_multi_vaps = true,
315 	.additional_gp_drv_bit = IWN_GP_DRIVER_NONE,
316 	.bt_mode = IWN_BT_SIMPLE,
317 	.plcp_err_threshold = IWN_PLCP_ERR_DEFAULT_THRESHOLD,
318 };
319 static const struct iwn_base_params iwn_6150_base_params = {
320 	.pll_cfg_val = 0,
321 	.max_ll_items = IWN_OTP_MAX_LL_ITEMS_6x50,
322 	.shadow_ram_support = true,
323 	.shadow_reg_enable = true,
324 	.bt_session_2 = false,
325 	.bt_sco_disable = true,
326 	.additional_nic_config = true,
327 	.regulatory_bands = iwn6000_regulatory_bands,
328 	.enhanced_TX_power = true,
329 	.calib_need =
330 	    (IWN_FLG_NEED_PHY_CALIB_LO
331 	    | IWN_FLG_NEED_PHY_CALIB_TX_IQ
332 	    | IWN_FLG_NEED_PHY_CALIB_BASE_BAND),
333 	.support_hostap = false,
334 	.no_multi_vaps = true,
335 	.additional_gp_drv_bit = IWN_GP_DRIVER_6050_1X2,
336 	.bt_mode = IWN_BT_SIMPLE,
337 	.plcp_err_threshold = IWN_PLCP_ERR_DEFAULT_THRESHOLD,
338 };
339 
340 /* IWL_DEVICE_6035 & IWL_DEVICE_6030 */
341 static const struct iwn_base_params iwn_6000g2b_base_params = {
342 	.pll_cfg_val = 0,
343 	.max_ll_items = IWN_OTP_MAX_LL_ITEMS_6x00,
344 	.shadow_ram_support = true,
345 	.shadow_reg_enable = true,
346 	.bt_session_2 = false,
347 	.bt_sco_disable = true,
348 	.additional_nic_config = false,
349 	.regulatory_bands = iwn6000_regulatory_bands,
350 	.enhanced_TX_power = true,
351 	.calib_need =
352 	    (IWN_FLG_NEED_PHY_CALIB_DC
353 	    | IWN_FLG_NEED_PHY_CALIB_LO
354 	    | IWN_FLG_NEED_PHY_CALIB_TX_IQ
355 	    | IWN_FLG_NEED_PHY_CALIB_BASE_BAND
356 	    | IWN_FLG_NEED_PHY_CALIB_TEMP_OFFSET ),
357 	.support_hostap = false,
358 	.no_multi_vaps = true,
359 	.additional_gp_drv_bit = IWN_GP_DRIVER_NONE,
360 	.bt_mode = IWN_BT_ADVANCED,
361 	.plcp_err_threshold = IWN_PLCP_ERR_DEFAULT_THRESHOLD,
362 };
363 
364 /*
365  * 6235 series NICs.
366  */
367 static const struct iwn_base_params iwn_6235_base_params = {
368 	.pll_cfg_val = 0,
369 	.max_ll_items = IWN_OTP_MAX_LL_ITEMS_6x00,
370 	.shadow_ram_support = true,
371 	.shadow_reg_enable = true,
372 	.bt_session_2 = false,
373 	.bt_sco_disable = true,
374 	.additional_nic_config = true,
375 	.regulatory_bands = iwn6000_regulatory_bands,
376 	.enhanced_TX_power = true,
377 	.calib_need =
378 	    (IWN_FLG_NEED_PHY_CALIB_DC
379 	    | IWN_FLG_NEED_PHY_CALIB_LO
380 	    | IWN_FLG_NEED_PHY_CALIB_TX_IQ
381 	    | IWN_FLG_NEED_PHY_CALIB_BASE_BAND
382 	    | IWN_FLG_NEED_PHY_CALIB_TEMP_OFFSET ),
383 	.support_hostap = false,
384 	.no_multi_vaps = true,
385 	/* XXX 1x2? This NIC is 2x2, right? */
386 	.additional_gp_drv_bit = IWN_GP_DRIVER_6050_1X2,
387 	.bt_mode = IWN_BT_ADVANCED,
388 	.plcp_err_threshold = IWN_PLCP_ERR_DEFAULT_THRESHOLD,
389 };
390 
391 static const struct iwn_base_params iwn_5x50_base_params = {
392 	.pll_cfg_val = IWN_ANA_PLL_INIT,
393 	.max_ll_items = IWN_OTP_MAX_LL_ITEMS_6x00,
394 	.shadow_ram_support = true,
395 	.shadow_reg_enable = false,
396 	.bt_session_2 = false,
397 	.bt_sco_disable = true,
398 	.additional_nic_config = false,
399 	.regulatory_bands = iwn5000_regulatory_bands,
400 	.enhanced_TX_power =false,
401 	.calib_need =
402 	    (IWN_FLG_NEED_PHY_CALIB_DC
403 	    | IWN_FLG_NEED_PHY_CALIB_LO
404 	    | IWN_FLG_NEED_PHY_CALIB_TX_IQ
405 	    | IWN_FLG_NEED_PHY_CALIB_BASE_BAND ),
406 	.support_hostap = false,
407 	.no_multi_vaps = true,
408 	.additional_gp_drv_bit = IWN_GP_DRIVER_NONE,
409 	.bt_mode = IWN_BT_SIMPLE,
410 	.plcp_err_threshold = IWN_PLCP_ERR_LONG_THRESHOLD,
411 };
412 
413 #endif	/* __IF_IWN_CHIP_CFG_H__ */
414