xref: /openbmc/linux/drivers/net/wireless/ti/wl12xx/main.c (revision 12eb4683)
1 /*
2  * This file is part of wl1271
3  *
4  * Copyright (C) 2008-2010 Nokia Corporation
5  *
6  * This program is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU General Public License
8  * version 2 as published by the Free Software Foundation.
9  *
10  * This program is distributed in the hope that it will be useful, but
11  * WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13  * General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License
16  * along with this program; if not, write to the Free Software
17  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
18  * 02110-1301 USA
19  *
20  */
21 
22 #include <linux/module.h>
23 #include <linux/platform_device.h>
24 
25 #include <linux/err.h>
26 
27 #include <linux/wl12xx.h>
28 
29 #include "../wlcore/wlcore.h"
30 #include "../wlcore/debug.h"
31 #include "../wlcore/io.h"
32 #include "../wlcore/acx.h"
33 #include "../wlcore/tx.h"
34 #include "../wlcore/rx.h"
35 #include "../wlcore/boot.h"
36 
37 #include "wl12xx.h"
38 #include "reg.h"
39 #include "cmd.h"
40 #include "acx.h"
41 #include "scan.h"
42 #include "event.h"
43 #include "debugfs.h"
44 
45 static char *fref_param;
46 static char *tcxo_param;
47 
48 static struct wlcore_conf wl12xx_conf = {
49 	.sg = {
50 		.params = {
51 			[CONF_SG_ACL_BT_MASTER_MIN_BR] = 10,
52 			[CONF_SG_ACL_BT_MASTER_MAX_BR] = 180,
53 			[CONF_SG_ACL_BT_SLAVE_MIN_BR] = 10,
54 			[CONF_SG_ACL_BT_SLAVE_MAX_BR] = 180,
55 			[CONF_SG_ACL_BT_MASTER_MIN_EDR] = 10,
56 			[CONF_SG_ACL_BT_MASTER_MAX_EDR] = 80,
57 			[CONF_SG_ACL_BT_SLAVE_MIN_EDR] = 10,
58 			[CONF_SG_ACL_BT_SLAVE_MAX_EDR] = 80,
59 			[CONF_SG_ACL_WLAN_PS_MASTER_BR] = 8,
60 			[CONF_SG_ACL_WLAN_PS_SLAVE_BR] = 8,
61 			[CONF_SG_ACL_WLAN_PS_MASTER_EDR] = 20,
62 			[CONF_SG_ACL_WLAN_PS_SLAVE_EDR] = 20,
63 			[CONF_SG_ACL_WLAN_ACTIVE_MASTER_MIN_BR] = 20,
64 			[CONF_SG_ACL_WLAN_ACTIVE_MASTER_MAX_BR] = 35,
65 			[CONF_SG_ACL_WLAN_ACTIVE_SLAVE_MIN_BR] = 16,
66 			[CONF_SG_ACL_WLAN_ACTIVE_SLAVE_MAX_BR] = 35,
67 			[CONF_SG_ACL_WLAN_ACTIVE_MASTER_MIN_EDR] = 32,
68 			[CONF_SG_ACL_WLAN_ACTIVE_MASTER_MAX_EDR] = 50,
69 			[CONF_SG_ACL_WLAN_ACTIVE_SLAVE_MIN_EDR] = 28,
70 			[CONF_SG_ACL_WLAN_ACTIVE_SLAVE_MAX_EDR] = 50,
71 			[CONF_SG_ACL_ACTIVE_SCAN_WLAN_BR] = 10,
72 			[CONF_SG_ACL_ACTIVE_SCAN_WLAN_EDR] = 20,
73 			[CONF_SG_ACL_PASSIVE_SCAN_BT_BR] = 75,
74 			[CONF_SG_ACL_PASSIVE_SCAN_WLAN_BR] = 15,
75 			[CONF_SG_ACL_PASSIVE_SCAN_BT_EDR] = 27,
76 			[CONF_SG_ACL_PASSIVE_SCAN_WLAN_EDR] = 17,
77 			/* active scan params */
78 			[CONF_SG_AUTO_SCAN_PROBE_REQ] = 170,
79 			[CONF_SG_ACTIVE_SCAN_DURATION_FACTOR_HV3] = 50,
80 			[CONF_SG_ACTIVE_SCAN_DURATION_FACTOR_A2DP] = 100,
81 			/* passive scan params */
82 			[CONF_SG_PASSIVE_SCAN_DURATION_FACTOR_A2DP_BR] = 800,
83 			[CONF_SG_PASSIVE_SCAN_DURATION_FACTOR_A2DP_EDR] = 200,
84 			[CONF_SG_PASSIVE_SCAN_DURATION_FACTOR_HV3] = 200,
85 			/* passive scan in dual antenna params */
86 			[CONF_SG_CONSECUTIVE_HV3_IN_PASSIVE_SCAN] = 0,
87 			[CONF_SG_BCN_HV3_COLLISION_THRESH_IN_PASSIVE_SCAN] = 0,
88 			[CONF_SG_TX_RX_PROTECTION_BWIDTH_IN_PASSIVE_SCAN] = 0,
89 			/* general params */
90 			[CONF_SG_STA_FORCE_PS_IN_BT_SCO] = 1,
91 			[CONF_SG_ANTENNA_CONFIGURATION] = 0,
92 			[CONF_SG_BEACON_MISS_PERCENT] = 60,
93 			[CONF_SG_DHCP_TIME] = 5000,
94 			[CONF_SG_RXT] = 1200,
95 			[CONF_SG_TXT] = 1000,
96 			[CONF_SG_ADAPTIVE_RXT_TXT] = 1,
97 			[CONF_SG_GENERAL_USAGE_BIT_MAP] = 3,
98 			[CONF_SG_HV3_MAX_SERVED] = 6,
99 			[CONF_SG_PS_POLL_TIMEOUT] = 10,
100 			[CONF_SG_UPSD_TIMEOUT] = 10,
101 			[CONF_SG_CONSECUTIVE_CTS_THRESHOLD] = 2,
102 			[CONF_SG_STA_RX_WINDOW_AFTER_DTIM] = 5,
103 			[CONF_SG_STA_CONNECTION_PROTECTION_TIME] = 30,
104 			/* AP params */
105 			[CONF_AP_BEACON_MISS_TX] = 3,
106 			[CONF_AP_RX_WINDOW_AFTER_BEACON] = 10,
107 			[CONF_AP_BEACON_WINDOW_INTERVAL] = 2,
108 			[CONF_AP_CONNECTION_PROTECTION_TIME] = 0,
109 			[CONF_AP_BT_ACL_VAL_BT_SERVE_TIME] = 25,
110 			[CONF_AP_BT_ACL_VAL_WL_SERVE_TIME] = 25,
111 			/* CTS Diluting params */
112 			[CONF_SG_CTS_DILUTED_BAD_RX_PACKETS_TH] = 0,
113 			[CONF_SG_CTS_CHOP_IN_DUAL_ANT_SCO_MASTER] = 0,
114 		},
115 		.state = CONF_SG_PROTECTIVE,
116 	},
117 	.rx = {
118 		.rx_msdu_life_time           = 512000,
119 		.packet_detection_threshold  = 0,
120 		.ps_poll_timeout             = 15,
121 		.upsd_timeout                = 15,
122 		.rts_threshold               = IEEE80211_MAX_RTS_THRESHOLD,
123 		.rx_cca_threshold            = 0,
124 		.irq_blk_threshold           = 0xFFFF,
125 		.irq_pkt_threshold           = 0,
126 		.irq_timeout                 = 600,
127 		.queue_type                  = CONF_RX_QUEUE_TYPE_LOW_PRIORITY,
128 	},
129 	.tx = {
130 		.tx_energy_detection         = 0,
131 		.sta_rc_conf                 = {
132 			.enabled_rates       = 0,
133 			.short_retry_limit   = 10,
134 			.long_retry_limit    = 10,
135 			.aflags              = 0,
136 		},
137 		.ac_conf_count               = 4,
138 		.ac_conf                     = {
139 			[CONF_TX_AC_BE] = {
140 				.ac          = CONF_TX_AC_BE,
141 				.cw_min      = 15,
142 				.cw_max      = 63,
143 				.aifsn       = 3,
144 				.tx_op_limit = 0,
145 			},
146 			[CONF_TX_AC_BK] = {
147 				.ac          = CONF_TX_AC_BK,
148 				.cw_min      = 15,
149 				.cw_max      = 63,
150 				.aifsn       = 7,
151 				.tx_op_limit = 0,
152 			},
153 			[CONF_TX_AC_VI] = {
154 				.ac          = CONF_TX_AC_VI,
155 				.cw_min      = 15,
156 				.cw_max      = 63,
157 				.aifsn       = CONF_TX_AIFS_PIFS,
158 				.tx_op_limit = 3008,
159 			},
160 			[CONF_TX_AC_VO] = {
161 				.ac          = CONF_TX_AC_VO,
162 				.cw_min      = 15,
163 				.cw_max      = 63,
164 				.aifsn       = CONF_TX_AIFS_PIFS,
165 				.tx_op_limit = 1504,
166 			},
167 		},
168 		.max_tx_retries = 100,
169 		.ap_aging_period = 300,
170 		.tid_conf_count = 4,
171 		.tid_conf = {
172 			[CONF_TX_AC_BE] = {
173 				.queue_id    = CONF_TX_AC_BE,
174 				.channel_type = CONF_CHANNEL_TYPE_EDCF,
175 				.tsid        = CONF_TX_AC_BE,
176 				.ps_scheme   = CONF_PS_SCHEME_LEGACY,
177 				.ack_policy  = CONF_ACK_POLICY_LEGACY,
178 				.apsd_conf   = {0, 0},
179 			},
180 			[CONF_TX_AC_BK] = {
181 				.queue_id    = CONF_TX_AC_BK,
182 				.channel_type = CONF_CHANNEL_TYPE_EDCF,
183 				.tsid        = CONF_TX_AC_BK,
184 				.ps_scheme   = CONF_PS_SCHEME_LEGACY,
185 				.ack_policy  = CONF_ACK_POLICY_LEGACY,
186 				.apsd_conf   = {0, 0},
187 			},
188 			[CONF_TX_AC_VI] = {
189 				.queue_id    = CONF_TX_AC_VI,
190 				.channel_type = CONF_CHANNEL_TYPE_EDCF,
191 				.tsid        = CONF_TX_AC_VI,
192 				.ps_scheme   = CONF_PS_SCHEME_LEGACY,
193 				.ack_policy  = CONF_ACK_POLICY_LEGACY,
194 				.apsd_conf   = {0, 0},
195 			},
196 			[CONF_TX_AC_VO] = {
197 				.queue_id    = CONF_TX_AC_VO,
198 				.channel_type = CONF_CHANNEL_TYPE_EDCF,
199 				.tsid        = CONF_TX_AC_VO,
200 				.ps_scheme   = CONF_PS_SCHEME_LEGACY,
201 				.ack_policy  = CONF_ACK_POLICY_LEGACY,
202 				.apsd_conf   = {0, 0},
203 			},
204 		},
205 		.frag_threshold              = IEEE80211_MAX_FRAG_THRESHOLD,
206 		.tx_compl_timeout            = 700,
207 		.tx_compl_threshold          = 4,
208 		.basic_rate                  = CONF_HW_BIT_RATE_1MBPS,
209 		.basic_rate_5                = CONF_HW_BIT_RATE_6MBPS,
210 		.tmpl_short_retry_limit      = 10,
211 		.tmpl_long_retry_limit       = 10,
212 		.tx_watchdog_timeout         = 5000,
213 		.slow_link_thold             = 3,
214 		.fast_link_thold             = 10,
215 	},
216 	.conn = {
217 		.wake_up_event               = CONF_WAKE_UP_EVENT_DTIM,
218 		.listen_interval             = 1,
219 		.suspend_wake_up_event       = CONF_WAKE_UP_EVENT_N_DTIM,
220 		.suspend_listen_interval     = 3,
221 		.bcn_filt_mode               = CONF_BCN_FILT_MODE_ENABLED,
222 		.bcn_filt_ie_count           = 3,
223 		.bcn_filt_ie = {
224 			[0] = {
225 				.ie          = WLAN_EID_CHANNEL_SWITCH,
226 				.rule        = CONF_BCN_RULE_PASS_ON_APPEARANCE,
227 			},
228 			[1] = {
229 				.ie          = WLAN_EID_HT_OPERATION,
230 				.rule        = CONF_BCN_RULE_PASS_ON_CHANGE,
231 			},
232 			[2] = {
233 				.ie	     = WLAN_EID_ERP_INFO,
234 				.rule	     = CONF_BCN_RULE_PASS_ON_CHANGE,
235 			},
236 		},
237 		.synch_fail_thold            = 12,
238 		.bss_lose_timeout            = 400,
239 		.beacon_rx_timeout           = 10000,
240 		.broadcast_timeout           = 20000,
241 		.rx_broadcast_in_ps          = 1,
242 		.ps_poll_threshold           = 10,
243 		.bet_enable                  = CONF_BET_MODE_ENABLE,
244 		.bet_max_consecutive         = 50,
245 		.psm_entry_retries           = 8,
246 		.psm_exit_retries            = 16,
247 		.psm_entry_nullfunc_retries  = 3,
248 		.dynamic_ps_timeout          = 1500,
249 		.forced_ps                   = false,
250 		.keep_alive_interval         = 55000,
251 		.max_listen_interval         = 20,
252 		.sta_sleep_auth              = WL1271_PSM_ILLEGAL,
253 	},
254 	.itrim = {
255 		.enable = false,
256 		.timeout = 50000,
257 	},
258 	.pm_config = {
259 		.host_clk_settling_time = 5000,
260 		.host_fast_wakeup_support = CONF_FAST_WAKEUP_DISABLE,
261 	},
262 	.roam_trigger = {
263 		.trigger_pacing               = 1,
264 		.avg_weight_rssi_beacon       = 20,
265 		.avg_weight_rssi_data         = 10,
266 		.avg_weight_snr_beacon        = 20,
267 		.avg_weight_snr_data          = 10,
268 	},
269 	.scan = {
270 		.min_dwell_time_active        = 7500,
271 		.max_dwell_time_active        = 30000,
272 		.min_dwell_time_active_long   = 25000,
273 		.max_dwell_time_active_long   = 50000,
274 		.dwell_time_passive           = 100000,
275 		.dwell_time_dfs               = 150000,
276 		.num_probe_reqs               = 2,
277 		.split_scan_timeout           = 50000,
278 	},
279 	.sched_scan = {
280 		/*
281 		 * Values are in TU/1000 but since sched scan FW command
282 		 * params are in TUs rounding up may occur.
283 		 */
284 		.base_dwell_time		= 7500,
285 		.max_dwell_time_delta		= 22500,
286 		/* based on 250bits per probe @1Mbps */
287 		.dwell_time_delta_per_probe	= 2000,
288 		/* based on 250bits per probe @6Mbps (plus a bit more) */
289 		.dwell_time_delta_per_probe_5	= 350,
290 		.dwell_time_passive		= 100000,
291 		.dwell_time_dfs			= 150000,
292 		.num_probe_reqs			= 2,
293 		.rssi_threshold			= -90,
294 		.snr_threshold			= 0,
295 	},
296 	.ht = {
297 		.rx_ba_win_size = 8,
298 		.tx_ba_win_size = 64,
299 		.inactivity_timeout = 10000,
300 		.tx_ba_tid_bitmap = CONF_TX_BA_ENABLED_TID_BITMAP,
301 	},
302 	/*
303 	 * Memory config for wl127x chips is given in the
304 	 * wl12xx_default_priv_conf struct. The below configuration is
305 	 * for wl128x chips.
306 	 */
307 	.mem = {
308 		.num_stations                 = 1,
309 		.ssid_profiles                = 1,
310 		.rx_block_num                 = 40,
311 		.tx_min_block_num             = 40,
312 		.dynamic_memory               = 1,
313 		.min_req_tx_blocks            = 45,
314 		.min_req_rx_blocks            = 22,
315 		.tx_min                       = 27,
316 	},
317 	.fm_coex = {
318 		.enable                       = true,
319 		.swallow_period               = 5,
320 		.n_divider_fref_set_1         = 0xff,       /* default */
321 		.n_divider_fref_set_2         = 12,
322 		.m_divider_fref_set_1         = 0xffff,
323 		.m_divider_fref_set_2         = 148,	    /* default */
324 		.coex_pll_stabilization_time  = 0xffffffff, /* default */
325 		.ldo_stabilization_time       = 0xffff,     /* default */
326 		.fm_disturbed_band_margin     = 0xff,       /* default */
327 		.swallow_clk_diff             = 0xff,       /* default */
328 	},
329 	.rx_streaming = {
330 		.duration                      = 150,
331 		.queues                        = 0x1,
332 		.interval                      = 20,
333 		.always                        = 0,
334 	},
335 	.fwlog = {
336 		.mode                         = WL12XX_FWLOG_CONTINUOUS,
337 		.mem_blocks                   = 2,
338 		.severity                     = 0,
339 		.timestamp                    = WL12XX_FWLOG_TIMESTAMP_DISABLED,
340 		.output                       = WL12XX_FWLOG_OUTPUT_DBG_PINS,
341 		.threshold                    = 0,
342 	},
343 	.rate = {
344 		.rate_retry_score = 32000,
345 		.per_add = 8192,
346 		.per_th1 = 2048,
347 		.per_th2 = 4096,
348 		.max_per = 8100,
349 		.inverse_curiosity_factor = 5,
350 		.tx_fail_low_th = 4,
351 		.tx_fail_high_th = 10,
352 		.per_alpha_shift = 4,
353 		.per_add_shift = 13,
354 		.per_beta1_shift = 10,
355 		.per_beta2_shift = 8,
356 		.rate_check_up = 2,
357 		.rate_check_down = 12,
358 		.rate_retry_policy = {
359 			0x00, 0x00, 0x00, 0x00, 0x00,
360 			0x00, 0x00, 0x00, 0x00, 0x00,
361 			0x00, 0x00, 0x00,
362 		},
363 	},
364 	.hangover = {
365 		.recover_time               = 0,
366 		.hangover_period            = 20,
367 		.dynamic_mode               = 1,
368 		.early_termination_mode     = 1,
369 		.max_period                 = 20,
370 		.min_period                 = 1,
371 		.increase_delta             = 1,
372 		.decrease_delta             = 2,
373 		.quiet_time                 = 4,
374 		.increase_time              = 1,
375 		.window_size                = 16,
376 	},
377 	.recovery = {
378 		.bug_on_recovery	    = 0,
379 		.no_recovery		    = 0,
380 	},
381 };
382 
383 static struct wl12xx_priv_conf wl12xx_default_priv_conf = {
384 	.rf = {
385 		.tx_per_channel_power_compensation_2 = {
386 			0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
387 		},
388 		.tx_per_channel_power_compensation_5 = {
389 			0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
390 			0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
391 			0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
392 		},
393 	},
394 	.mem_wl127x = {
395 		.num_stations                 = 1,
396 		.ssid_profiles                = 1,
397 		.rx_block_num                 = 70,
398 		.tx_min_block_num             = 40,
399 		.dynamic_memory               = 1,
400 		.min_req_tx_blocks            = 100,
401 		.min_req_rx_blocks            = 22,
402 		.tx_min                       = 27,
403 	},
404 
405 };
406 
407 #define WL12XX_TX_HW_BLOCK_SPARE_DEFAULT        1
408 #define WL12XX_TX_HW_BLOCK_GEM_SPARE            2
409 #define WL12XX_TX_HW_BLOCK_SIZE                 252
410 
411 static const u8 wl12xx_rate_to_idx_2ghz[] = {
412 	/* MCS rates are used only with 11n */
413 	7,                             /* WL12XX_CONF_HW_RXTX_RATE_MCS7_SGI */
414 	7,                             /* WL12XX_CONF_HW_RXTX_RATE_MCS7 */
415 	6,                             /* WL12XX_CONF_HW_RXTX_RATE_MCS6 */
416 	5,                             /* WL12XX_CONF_HW_RXTX_RATE_MCS5 */
417 	4,                             /* WL12XX_CONF_HW_RXTX_RATE_MCS4 */
418 	3,                             /* WL12XX_CONF_HW_RXTX_RATE_MCS3 */
419 	2,                             /* WL12XX_CONF_HW_RXTX_RATE_MCS2 */
420 	1,                             /* WL12XX_CONF_HW_RXTX_RATE_MCS1 */
421 	0,                             /* WL12XX_CONF_HW_RXTX_RATE_MCS0 */
422 
423 	11,                            /* WL12XX_CONF_HW_RXTX_RATE_54   */
424 	10,                            /* WL12XX_CONF_HW_RXTX_RATE_48   */
425 	9,                             /* WL12XX_CONF_HW_RXTX_RATE_36   */
426 	8,                             /* WL12XX_CONF_HW_RXTX_RATE_24   */
427 
428 	/* TI-specific rate */
429 	CONF_HW_RXTX_RATE_UNSUPPORTED, /* WL12XX_CONF_HW_RXTX_RATE_22   */
430 
431 	7,                             /* WL12XX_CONF_HW_RXTX_RATE_18   */
432 	6,                             /* WL12XX_CONF_HW_RXTX_RATE_12   */
433 	3,                             /* WL12XX_CONF_HW_RXTX_RATE_11   */
434 	5,                             /* WL12XX_CONF_HW_RXTX_RATE_9    */
435 	4,                             /* WL12XX_CONF_HW_RXTX_RATE_6    */
436 	2,                             /* WL12XX_CONF_HW_RXTX_RATE_5_5  */
437 	1,                             /* WL12XX_CONF_HW_RXTX_RATE_2    */
438 	0                              /* WL12XX_CONF_HW_RXTX_RATE_1    */
439 };
440 
441 static const u8 wl12xx_rate_to_idx_5ghz[] = {
442 	/* MCS rates are used only with 11n */
443 	7,                             /* WL12XX_CONF_HW_RXTX_RATE_MCS7_SGI */
444 	7,                             /* WL12XX_CONF_HW_RXTX_RATE_MCS7 */
445 	6,                             /* WL12XX_CONF_HW_RXTX_RATE_MCS6 */
446 	5,                             /* WL12XX_CONF_HW_RXTX_RATE_MCS5 */
447 	4,                             /* WL12XX_CONF_HW_RXTX_RATE_MCS4 */
448 	3,                             /* WL12XX_CONF_HW_RXTX_RATE_MCS3 */
449 	2,                             /* WL12XX_CONF_HW_RXTX_RATE_MCS2 */
450 	1,                             /* WL12XX_CONF_HW_RXTX_RATE_MCS1 */
451 	0,                             /* WL12XX_CONF_HW_RXTX_RATE_MCS0 */
452 
453 	7,                             /* WL12XX_CONF_HW_RXTX_RATE_54   */
454 	6,                             /* WL12XX_CONF_HW_RXTX_RATE_48   */
455 	5,                             /* WL12XX_CONF_HW_RXTX_RATE_36   */
456 	4,                             /* WL12XX_CONF_HW_RXTX_RATE_24   */
457 
458 	/* TI-specific rate */
459 	CONF_HW_RXTX_RATE_UNSUPPORTED, /* WL12XX_CONF_HW_RXTX_RATE_22   */
460 
461 	3,                             /* WL12XX_CONF_HW_RXTX_RATE_18   */
462 	2,                             /* WL12XX_CONF_HW_RXTX_RATE_12   */
463 	CONF_HW_RXTX_RATE_UNSUPPORTED, /* WL12XX_CONF_HW_RXTX_RATE_11   */
464 	1,                             /* WL12XX_CONF_HW_RXTX_RATE_9    */
465 	0,                             /* WL12XX_CONF_HW_RXTX_RATE_6    */
466 	CONF_HW_RXTX_RATE_UNSUPPORTED, /* WL12XX_CONF_HW_RXTX_RATE_5_5  */
467 	CONF_HW_RXTX_RATE_UNSUPPORTED, /* WL12XX_CONF_HW_RXTX_RATE_2    */
468 	CONF_HW_RXTX_RATE_UNSUPPORTED  /* WL12XX_CONF_HW_RXTX_RATE_1    */
469 };
470 
471 static const u8 *wl12xx_band_rate_to_idx[] = {
472 	[IEEE80211_BAND_2GHZ] = wl12xx_rate_to_idx_2ghz,
473 	[IEEE80211_BAND_5GHZ] = wl12xx_rate_to_idx_5ghz
474 };
475 
476 enum wl12xx_hw_rates {
477 	WL12XX_CONF_HW_RXTX_RATE_MCS7_SGI = 0,
478 	WL12XX_CONF_HW_RXTX_RATE_MCS7,
479 	WL12XX_CONF_HW_RXTX_RATE_MCS6,
480 	WL12XX_CONF_HW_RXTX_RATE_MCS5,
481 	WL12XX_CONF_HW_RXTX_RATE_MCS4,
482 	WL12XX_CONF_HW_RXTX_RATE_MCS3,
483 	WL12XX_CONF_HW_RXTX_RATE_MCS2,
484 	WL12XX_CONF_HW_RXTX_RATE_MCS1,
485 	WL12XX_CONF_HW_RXTX_RATE_MCS0,
486 	WL12XX_CONF_HW_RXTX_RATE_54,
487 	WL12XX_CONF_HW_RXTX_RATE_48,
488 	WL12XX_CONF_HW_RXTX_RATE_36,
489 	WL12XX_CONF_HW_RXTX_RATE_24,
490 	WL12XX_CONF_HW_RXTX_RATE_22,
491 	WL12XX_CONF_HW_RXTX_RATE_18,
492 	WL12XX_CONF_HW_RXTX_RATE_12,
493 	WL12XX_CONF_HW_RXTX_RATE_11,
494 	WL12XX_CONF_HW_RXTX_RATE_9,
495 	WL12XX_CONF_HW_RXTX_RATE_6,
496 	WL12XX_CONF_HW_RXTX_RATE_5_5,
497 	WL12XX_CONF_HW_RXTX_RATE_2,
498 	WL12XX_CONF_HW_RXTX_RATE_1,
499 	WL12XX_CONF_HW_RXTX_RATE_MAX,
500 };
501 
502 static struct wlcore_partition_set wl12xx_ptable[PART_TABLE_LEN] = {
503 	[PART_DOWN] = {
504 		.mem = {
505 			.start = 0x00000000,
506 			.size  = 0x000177c0
507 		},
508 		.reg = {
509 			.start = REGISTERS_BASE,
510 			.size  = 0x00008800
511 		},
512 		.mem2 = {
513 			.start = 0x00000000,
514 			.size  = 0x00000000
515 		},
516 		.mem3 = {
517 			.start = 0x00000000,
518 			.size  = 0x00000000
519 		},
520 	},
521 
522 	[PART_BOOT] = { /* in wl12xx we can use a mix of work and down
523 			 * partition here */
524 		.mem = {
525 			.start = 0x00040000,
526 			.size  = 0x00014fc0
527 		},
528 		.reg = {
529 			.start = REGISTERS_BASE,
530 			.size  = 0x00008800
531 		},
532 		.mem2 = {
533 			.start = 0x00000000,
534 			.size  = 0x00000000
535 		},
536 		.mem3 = {
537 			.start = 0x00000000,
538 			.size  = 0x00000000
539 		},
540 	},
541 
542 	[PART_WORK] = {
543 		.mem = {
544 			.start = 0x00040000,
545 			.size  = 0x00014fc0
546 		},
547 		.reg = {
548 			.start = REGISTERS_BASE,
549 			.size  = 0x0000a000
550 		},
551 		.mem2 = {
552 			.start = 0x003004f8,
553 			.size  = 0x00000004
554 		},
555 		.mem3 = {
556 			.start = 0x00040404,
557 			.size  = 0x00000000
558 		},
559 	},
560 
561 	[PART_DRPW] = {
562 		.mem = {
563 			.start = 0x00040000,
564 			.size  = 0x00014fc0
565 		},
566 		.reg = {
567 			.start = DRPW_BASE,
568 			.size  = 0x00006000
569 		},
570 		.mem2 = {
571 			.start = 0x00000000,
572 			.size  = 0x00000000
573 		},
574 		.mem3 = {
575 			.start = 0x00000000,
576 			.size  = 0x00000000
577 		}
578 	}
579 };
580 
581 static const int wl12xx_rtable[REG_TABLE_LEN] = {
582 	[REG_ECPU_CONTROL]		= WL12XX_REG_ECPU_CONTROL,
583 	[REG_INTERRUPT_NO_CLEAR]	= WL12XX_REG_INTERRUPT_NO_CLEAR,
584 	[REG_INTERRUPT_ACK]		= WL12XX_REG_INTERRUPT_ACK,
585 	[REG_COMMAND_MAILBOX_PTR]	= WL12XX_REG_COMMAND_MAILBOX_PTR,
586 	[REG_EVENT_MAILBOX_PTR]		= WL12XX_REG_EVENT_MAILBOX_PTR,
587 	[REG_INTERRUPT_TRIG]		= WL12XX_REG_INTERRUPT_TRIG,
588 	[REG_INTERRUPT_MASK]		= WL12XX_REG_INTERRUPT_MASK,
589 	[REG_PC_ON_RECOVERY]		= WL12XX_SCR_PAD4,
590 	[REG_CHIP_ID_B]			= WL12XX_CHIP_ID_B,
591 	[REG_CMD_MBOX_ADDRESS]		= WL12XX_CMD_MBOX_ADDRESS,
592 
593 	/* data access memory addresses, used with partition translation */
594 	[REG_SLV_MEM_DATA]		= WL1271_SLV_MEM_DATA,
595 	[REG_SLV_REG_DATA]		= WL1271_SLV_REG_DATA,
596 
597 	/* raw data access memory addresses */
598 	[REG_RAW_FW_STATUS_ADDR]	= FW_STATUS_ADDR,
599 };
600 
601 /* TODO: maybe move to a new header file? */
602 #define WL127X_FW_NAME_MULTI	"ti-connectivity/wl127x-fw-5-mr.bin"
603 #define WL127X_FW_NAME_SINGLE	"ti-connectivity/wl127x-fw-5-sr.bin"
604 #define WL127X_PLT_FW_NAME	"ti-connectivity/wl127x-fw-5-plt.bin"
605 
606 #define WL128X_FW_NAME_MULTI	"ti-connectivity/wl128x-fw-5-mr.bin"
607 #define WL128X_FW_NAME_SINGLE	"ti-connectivity/wl128x-fw-5-sr.bin"
608 #define WL128X_PLT_FW_NAME	"ti-connectivity/wl128x-fw-5-plt.bin"
609 
610 static int wl127x_prepare_read(struct wl1271 *wl, u32 rx_desc, u32 len)
611 {
612 	int ret;
613 
614 	if (wl->chip.id != CHIP_ID_128X_PG20) {
615 		struct wl1271_acx_mem_map *wl_mem_map = wl->target_mem_map;
616 		struct wl12xx_priv *priv = wl->priv;
617 
618 		/*
619 		 * Choose the block we want to read
620 		 * For aggregated packets, only the first memory block
621 		 * should be retrieved. The FW takes care of the rest.
622 		 */
623 		u32 mem_block = rx_desc & RX_MEM_BLOCK_MASK;
624 
625 		priv->rx_mem_addr->addr = (mem_block << 8) +
626 			le32_to_cpu(wl_mem_map->packet_memory_pool_start);
627 
628 		priv->rx_mem_addr->addr_extra = priv->rx_mem_addr->addr + 4;
629 
630 		ret = wlcore_write(wl, WL1271_SLV_REG_DATA, priv->rx_mem_addr,
631 				   sizeof(*priv->rx_mem_addr), false);
632 		if (ret < 0)
633 			return ret;
634 	}
635 
636 	return 0;
637 }
638 
639 static int wl12xx_identify_chip(struct wl1271 *wl)
640 {
641 	int ret = 0;
642 
643 	switch (wl->chip.id) {
644 	case CHIP_ID_127X_PG10:
645 		wl1271_warning("chip id 0x%x (1271 PG10) support is obsolete",
646 			       wl->chip.id);
647 
648 		wl->quirks |= WLCORE_QUIRK_LEGACY_NVS |
649 			      WLCORE_QUIRK_DUAL_PROBE_TMPL |
650 			      WLCORE_QUIRK_TKIP_HEADER_SPACE |
651 			      WLCORE_QUIRK_START_STA_FAILS |
652 			      WLCORE_QUIRK_AP_ZERO_SESSION_ID;
653 		wl->sr_fw_name = WL127X_FW_NAME_SINGLE;
654 		wl->mr_fw_name = WL127X_FW_NAME_MULTI;
655 		memcpy(&wl->conf.mem, &wl12xx_default_priv_conf.mem_wl127x,
656 		       sizeof(wl->conf.mem));
657 
658 		/* read data preparation is only needed by wl127x */
659 		wl->ops->prepare_read = wl127x_prepare_read;
660 
661 		wlcore_set_min_fw_ver(wl, WL127X_CHIP_VER,
662 			      WL127X_IFTYPE_SR_VER,  WL127X_MAJOR_SR_VER,
663 			      WL127X_SUBTYPE_SR_VER, WL127X_MINOR_SR_VER,
664 			      WL127X_IFTYPE_MR_VER,  WL127X_MAJOR_MR_VER,
665 			      WL127X_SUBTYPE_MR_VER, WL127X_MINOR_MR_VER);
666 		break;
667 
668 	case CHIP_ID_127X_PG20:
669 		wl1271_debug(DEBUG_BOOT, "chip id 0x%x (1271 PG20)",
670 			     wl->chip.id);
671 
672 		wl->quirks |= WLCORE_QUIRK_LEGACY_NVS |
673 			      WLCORE_QUIRK_DUAL_PROBE_TMPL |
674 			      WLCORE_QUIRK_TKIP_HEADER_SPACE |
675 			      WLCORE_QUIRK_START_STA_FAILS |
676 			      WLCORE_QUIRK_AP_ZERO_SESSION_ID;
677 		wl->plt_fw_name = WL127X_PLT_FW_NAME;
678 		wl->sr_fw_name = WL127X_FW_NAME_SINGLE;
679 		wl->mr_fw_name = WL127X_FW_NAME_MULTI;
680 		memcpy(&wl->conf.mem, &wl12xx_default_priv_conf.mem_wl127x,
681 		       sizeof(wl->conf.mem));
682 
683 		/* read data preparation is only needed by wl127x */
684 		wl->ops->prepare_read = wl127x_prepare_read;
685 
686 		wlcore_set_min_fw_ver(wl, WL127X_CHIP_VER,
687 			      WL127X_IFTYPE_SR_VER,  WL127X_MAJOR_SR_VER,
688 			      WL127X_SUBTYPE_SR_VER, WL127X_MINOR_SR_VER,
689 			      WL127X_IFTYPE_MR_VER,  WL127X_MAJOR_MR_VER,
690 			      WL127X_SUBTYPE_MR_VER, WL127X_MINOR_MR_VER);
691 		break;
692 
693 	case CHIP_ID_128X_PG20:
694 		wl1271_debug(DEBUG_BOOT, "chip id 0x%x (1283 PG20)",
695 			     wl->chip.id);
696 		wl->plt_fw_name = WL128X_PLT_FW_NAME;
697 		wl->sr_fw_name = WL128X_FW_NAME_SINGLE;
698 		wl->mr_fw_name = WL128X_FW_NAME_MULTI;
699 
700 		/* wl128x requires TX blocksize alignment */
701 		wl->quirks |= WLCORE_QUIRK_TX_BLOCKSIZE_ALIGN |
702 			      WLCORE_QUIRK_DUAL_PROBE_TMPL |
703 			      WLCORE_QUIRK_TKIP_HEADER_SPACE |
704 			      WLCORE_QUIRK_START_STA_FAILS |
705 			      WLCORE_QUIRK_AP_ZERO_SESSION_ID;
706 
707 		wlcore_set_min_fw_ver(wl, WL128X_CHIP_VER,
708 			      WL128X_IFTYPE_SR_VER,  WL128X_MAJOR_SR_VER,
709 			      WL128X_SUBTYPE_SR_VER, WL128X_MINOR_SR_VER,
710 			      WL128X_IFTYPE_MR_VER,  WL128X_MAJOR_MR_VER,
711 			      WL128X_SUBTYPE_MR_VER, WL128X_MINOR_MR_VER);
712 		break;
713 	case CHIP_ID_128X_PG10:
714 	default:
715 		wl1271_warning("unsupported chip id: 0x%x", wl->chip.id);
716 		ret = -ENODEV;
717 		goto out;
718 	}
719 
720 	wl->fw_mem_block_size = 256;
721 	wl->fwlog_end = 0x2000000;
722 
723 	/* common settings */
724 	wl->scan_templ_id_2_4 = CMD_TEMPL_APP_PROBE_REQ_2_4_LEGACY;
725 	wl->scan_templ_id_5 = CMD_TEMPL_APP_PROBE_REQ_5_LEGACY;
726 	wl->sched_scan_templ_id_2_4 = CMD_TEMPL_CFG_PROBE_REQ_2_4;
727 	wl->sched_scan_templ_id_5 = CMD_TEMPL_CFG_PROBE_REQ_5;
728 	wl->max_channels_5 = WL12XX_MAX_CHANNELS_5GHZ;
729 	wl->ba_rx_session_count_max = WL12XX_RX_BA_MAX_SESSIONS;
730 out:
731 	return ret;
732 }
733 
734 static int __must_check wl12xx_top_reg_write(struct wl1271 *wl, int addr,
735 					     u16 val)
736 {
737 	int ret;
738 
739 	/* write address >> 1 + 0x30000 to OCP_POR_CTR */
740 	addr = (addr >> 1) + 0x30000;
741 	ret = wlcore_write32(wl, WL12XX_OCP_POR_CTR, addr);
742 	if (ret < 0)
743 		goto out;
744 
745 	/* write value to OCP_POR_WDATA */
746 	ret = wlcore_write32(wl, WL12XX_OCP_DATA_WRITE, val);
747 	if (ret < 0)
748 		goto out;
749 
750 	/* write 1 to OCP_CMD */
751 	ret = wlcore_write32(wl, WL12XX_OCP_CMD, OCP_CMD_WRITE);
752 	if (ret < 0)
753 		goto out;
754 
755 out:
756 	return ret;
757 }
758 
759 static int __must_check wl12xx_top_reg_read(struct wl1271 *wl, int addr,
760 					    u16 *out)
761 {
762 	u32 val;
763 	int timeout = OCP_CMD_LOOP;
764 	int ret;
765 
766 	/* write address >> 1 + 0x30000 to OCP_POR_CTR */
767 	addr = (addr >> 1) + 0x30000;
768 	ret = wlcore_write32(wl, WL12XX_OCP_POR_CTR, addr);
769 	if (ret < 0)
770 		return ret;
771 
772 	/* write 2 to OCP_CMD */
773 	ret = wlcore_write32(wl, WL12XX_OCP_CMD, OCP_CMD_READ);
774 	if (ret < 0)
775 		return ret;
776 
777 	/* poll for data ready */
778 	do {
779 		ret = wlcore_read32(wl, WL12XX_OCP_DATA_READ, &val);
780 		if (ret < 0)
781 			return ret;
782 	} while (!(val & OCP_READY_MASK) && --timeout);
783 
784 	if (!timeout) {
785 		wl1271_warning("Top register access timed out.");
786 		return -ETIMEDOUT;
787 	}
788 
789 	/* check data status and return if OK */
790 	if ((val & OCP_STATUS_MASK) != OCP_STATUS_OK) {
791 		wl1271_warning("Top register access returned error.");
792 		return -EIO;
793 	}
794 
795 	if (out)
796 		*out = val & 0xffff;
797 
798 	return 0;
799 }
800 
801 static int wl128x_switch_tcxo_to_fref(struct wl1271 *wl)
802 {
803 	u16 spare_reg;
804 	int ret;
805 
806 	/* Mask bits [2] & [8:4] in the sys_clk_cfg register */
807 	ret = wl12xx_top_reg_read(wl, WL_SPARE_REG, &spare_reg);
808 	if (ret < 0)
809 		return ret;
810 
811 	if (spare_reg == 0xFFFF)
812 		return -EFAULT;
813 	spare_reg |= (BIT(3) | BIT(5) | BIT(6));
814 	ret = wl12xx_top_reg_write(wl, WL_SPARE_REG, spare_reg);
815 	if (ret < 0)
816 		return ret;
817 
818 	/* Enable FREF_CLK_REQ & mux MCS and coex PLLs to FREF */
819 	ret = wl12xx_top_reg_write(wl, SYS_CLK_CFG_REG,
820 				   WL_CLK_REQ_TYPE_PG2 | MCS_PLL_CLK_SEL_FREF);
821 	if (ret < 0)
822 		return ret;
823 
824 	/* Delay execution for 15msec, to let the HW settle */
825 	mdelay(15);
826 
827 	return 0;
828 }
829 
830 static bool wl128x_is_tcxo_valid(struct wl1271 *wl)
831 {
832 	u16 tcxo_detection;
833 	int ret;
834 
835 	ret = wl12xx_top_reg_read(wl, TCXO_CLK_DETECT_REG, &tcxo_detection);
836 	if (ret < 0)
837 		return false;
838 
839 	if (tcxo_detection & TCXO_DET_FAILED)
840 		return false;
841 
842 	return true;
843 }
844 
845 static bool wl128x_is_fref_valid(struct wl1271 *wl)
846 {
847 	u16 fref_detection;
848 	int ret;
849 
850 	ret = wl12xx_top_reg_read(wl, FREF_CLK_DETECT_REG, &fref_detection);
851 	if (ret < 0)
852 		return false;
853 
854 	if (fref_detection & FREF_CLK_DETECT_FAIL)
855 		return false;
856 
857 	return true;
858 }
859 
860 static int wl128x_manually_configure_mcs_pll(struct wl1271 *wl)
861 {
862 	int ret;
863 
864 	ret = wl12xx_top_reg_write(wl, MCS_PLL_M_REG, MCS_PLL_M_REG_VAL);
865 	if (ret < 0)
866 		goto out;
867 
868 	ret = wl12xx_top_reg_write(wl, MCS_PLL_N_REG, MCS_PLL_N_REG_VAL);
869 	if (ret < 0)
870 		goto out;
871 
872 	ret = wl12xx_top_reg_write(wl, MCS_PLL_CONFIG_REG,
873 				   MCS_PLL_CONFIG_REG_VAL);
874 
875 out:
876 	return ret;
877 }
878 
879 static int wl128x_configure_mcs_pll(struct wl1271 *wl, int clk)
880 {
881 	u16 spare_reg;
882 	u16 pll_config;
883 	u8 input_freq;
884 	struct wl12xx_priv *priv = wl->priv;
885 	int ret;
886 
887 	/* Mask bits [3:1] in the sys_clk_cfg register */
888 	ret = wl12xx_top_reg_read(wl, WL_SPARE_REG, &spare_reg);
889 	if (ret < 0)
890 		return ret;
891 
892 	if (spare_reg == 0xFFFF)
893 		return -EFAULT;
894 	spare_reg |= BIT(2);
895 	ret = wl12xx_top_reg_write(wl, WL_SPARE_REG, spare_reg);
896 	if (ret < 0)
897 		return ret;
898 
899 	/* Handle special cases of the TCXO clock */
900 	if (priv->tcxo_clock == WL12XX_TCXOCLOCK_16_8 ||
901 	    priv->tcxo_clock == WL12XX_TCXOCLOCK_33_6)
902 		return wl128x_manually_configure_mcs_pll(wl);
903 
904 	/* Set the input frequency according to the selected clock source */
905 	input_freq = (clk & 1) + 1;
906 
907 	ret = wl12xx_top_reg_read(wl, MCS_PLL_CONFIG_REG, &pll_config);
908 	if (ret < 0)
909 		return ret;
910 
911 	if (pll_config == 0xFFFF)
912 		return -EFAULT;
913 	pll_config |= (input_freq << MCS_SEL_IN_FREQ_SHIFT);
914 	pll_config |= MCS_PLL_ENABLE_HP;
915 	ret = wl12xx_top_reg_write(wl, MCS_PLL_CONFIG_REG, pll_config);
916 
917 	return ret;
918 }
919 
920 /*
921  * WL128x has two clocks input - TCXO and FREF.
922  * TCXO is the main clock of the device, while FREF is used to sync
923  * between the GPS and the cellular modem.
924  * In cases where TCXO is 32.736MHz or 16.368MHz, the FREF will be used
925  * as the WLAN/BT main clock.
926  */
927 static int wl128x_boot_clk(struct wl1271 *wl, int *selected_clock)
928 {
929 	struct wl12xx_priv *priv = wl->priv;
930 	u16 sys_clk_cfg;
931 	int ret;
932 
933 	/* For XTAL-only modes, FREF will be used after switching from TCXO */
934 	if (priv->ref_clock == WL12XX_REFCLOCK_26_XTAL ||
935 	    priv->ref_clock == WL12XX_REFCLOCK_38_XTAL) {
936 		if (!wl128x_switch_tcxo_to_fref(wl))
937 			return -EINVAL;
938 		goto fref_clk;
939 	}
940 
941 	/* Query the HW, to determine which clock source we should use */
942 	ret = wl12xx_top_reg_read(wl, SYS_CLK_CFG_REG, &sys_clk_cfg);
943 	if (ret < 0)
944 		return ret;
945 
946 	if (sys_clk_cfg == 0xFFFF)
947 		return -EINVAL;
948 	if (sys_clk_cfg & PRCM_CM_EN_MUX_WLAN_FREF)
949 		goto fref_clk;
950 
951 	/* If TCXO is either 32.736MHz or 16.368MHz, switch to FREF */
952 	if (priv->tcxo_clock == WL12XX_TCXOCLOCK_16_368 ||
953 	    priv->tcxo_clock == WL12XX_TCXOCLOCK_32_736) {
954 		if (!wl128x_switch_tcxo_to_fref(wl))
955 			return -EINVAL;
956 		goto fref_clk;
957 	}
958 
959 	/* TCXO clock is selected */
960 	if (!wl128x_is_tcxo_valid(wl))
961 		return -EINVAL;
962 	*selected_clock = priv->tcxo_clock;
963 	goto config_mcs_pll;
964 
965 fref_clk:
966 	/* FREF clock is selected */
967 	if (!wl128x_is_fref_valid(wl))
968 		return -EINVAL;
969 	*selected_clock = priv->ref_clock;
970 
971 config_mcs_pll:
972 	return wl128x_configure_mcs_pll(wl, *selected_clock);
973 }
974 
975 static int wl127x_boot_clk(struct wl1271 *wl)
976 {
977 	struct wl12xx_priv *priv = wl->priv;
978 	u32 pause;
979 	u32 clk;
980 	int ret;
981 
982 	if (WL127X_PG_GET_MAJOR(wl->hw_pg_ver) < 3)
983 		wl->quirks |= WLCORE_QUIRK_END_OF_TRANSACTION;
984 
985 	if (priv->ref_clock == CONF_REF_CLK_19_2_E ||
986 	    priv->ref_clock == CONF_REF_CLK_38_4_E ||
987 	    priv->ref_clock == CONF_REF_CLK_38_4_M_XTAL)
988 		/* ref clk: 19.2/38.4/38.4-XTAL */
989 		clk = 0x3;
990 	else if (priv->ref_clock == CONF_REF_CLK_26_E ||
991 		 priv->ref_clock == CONF_REF_CLK_26_M_XTAL ||
992 		 priv->ref_clock == CONF_REF_CLK_52_E)
993 		/* ref clk: 26/52 */
994 		clk = 0x5;
995 	else
996 		return -EINVAL;
997 
998 	if (priv->ref_clock != CONF_REF_CLK_19_2_E) {
999 		u16 val;
1000 		/* Set clock type (open drain) */
1001 		ret = wl12xx_top_reg_read(wl, OCP_REG_CLK_TYPE, &val);
1002 		if (ret < 0)
1003 			goto out;
1004 
1005 		val &= FREF_CLK_TYPE_BITS;
1006 		ret = wl12xx_top_reg_write(wl, OCP_REG_CLK_TYPE, val);
1007 		if (ret < 0)
1008 			goto out;
1009 
1010 		/* Set clock pull mode (no pull) */
1011 		ret = wl12xx_top_reg_read(wl, OCP_REG_CLK_PULL, &val);
1012 		if (ret < 0)
1013 			goto out;
1014 
1015 		val |= NO_PULL;
1016 		ret = wl12xx_top_reg_write(wl, OCP_REG_CLK_PULL, val);
1017 		if (ret < 0)
1018 			goto out;
1019 	} else {
1020 		u16 val;
1021 		/* Set clock polarity */
1022 		ret = wl12xx_top_reg_read(wl, OCP_REG_CLK_POLARITY, &val);
1023 		if (ret < 0)
1024 			goto out;
1025 
1026 		val &= FREF_CLK_POLARITY_BITS;
1027 		val |= CLK_REQ_OUTN_SEL;
1028 		ret = wl12xx_top_reg_write(wl, OCP_REG_CLK_POLARITY, val);
1029 		if (ret < 0)
1030 			goto out;
1031 	}
1032 
1033 	ret = wlcore_write32(wl, WL12XX_PLL_PARAMETERS, clk);
1034 	if (ret < 0)
1035 		goto out;
1036 
1037 	ret = wlcore_read32(wl, WL12XX_PLL_PARAMETERS, &pause);
1038 	if (ret < 0)
1039 		goto out;
1040 
1041 	wl1271_debug(DEBUG_BOOT, "pause1 0x%x", pause);
1042 
1043 	pause &= ~(WU_COUNTER_PAUSE_VAL);
1044 	pause |= WU_COUNTER_PAUSE_VAL;
1045 	ret = wlcore_write32(wl, WL12XX_WU_COUNTER_PAUSE, pause);
1046 
1047 out:
1048 	return ret;
1049 }
1050 
1051 static int wl1271_boot_soft_reset(struct wl1271 *wl)
1052 {
1053 	unsigned long timeout;
1054 	u32 boot_data;
1055 	int ret = 0;
1056 
1057 	/* perform soft reset */
1058 	ret = wlcore_write32(wl, WL12XX_SLV_SOFT_RESET, ACX_SLV_SOFT_RESET_BIT);
1059 	if (ret < 0)
1060 		goto out;
1061 
1062 	/* SOFT_RESET is self clearing */
1063 	timeout = jiffies + usecs_to_jiffies(SOFT_RESET_MAX_TIME);
1064 	while (1) {
1065 		ret = wlcore_read32(wl, WL12XX_SLV_SOFT_RESET, &boot_data);
1066 		if (ret < 0)
1067 			goto out;
1068 
1069 		wl1271_debug(DEBUG_BOOT, "soft reset bootdata 0x%x", boot_data);
1070 		if ((boot_data & ACX_SLV_SOFT_RESET_BIT) == 0)
1071 			break;
1072 
1073 		if (time_after(jiffies, timeout)) {
1074 			/* 1.2 check pWhalBus->uSelfClearTime if the
1075 			 * timeout was reached */
1076 			wl1271_error("soft reset timeout");
1077 			return -1;
1078 		}
1079 
1080 		udelay(SOFT_RESET_STALL_TIME);
1081 	}
1082 
1083 	/* disable Rx/Tx */
1084 	ret = wlcore_write32(wl, WL12XX_ENABLE, 0x0);
1085 	if (ret < 0)
1086 		goto out;
1087 
1088 	/* disable auto calibration on start*/
1089 	ret = wlcore_write32(wl, WL12XX_SPARE_A2, 0xffff);
1090 
1091 out:
1092 	return ret;
1093 }
1094 
1095 static int wl12xx_pre_boot(struct wl1271 *wl)
1096 {
1097 	struct wl12xx_priv *priv = wl->priv;
1098 	int ret = 0;
1099 	u32 clk;
1100 	int selected_clock = -1;
1101 
1102 	if (wl->chip.id == CHIP_ID_128X_PG20) {
1103 		ret = wl128x_boot_clk(wl, &selected_clock);
1104 		if (ret < 0)
1105 			goto out;
1106 	} else {
1107 		ret = wl127x_boot_clk(wl);
1108 		if (ret < 0)
1109 			goto out;
1110 	}
1111 
1112 	/* Continue the ELP wake up sequence */
1113 	ret = wlcore_write32(wl, WL12XX_WELP_ARM_COMMAND, WELP_ARM_COMMAND_VAL);
1114 	if (ret < 0)
1115 		goto out;
1116 
1117 	udelay(500);
1118 
1119 	ret = wlcore_set_partition(wl, &wl->ptable[PART_DRPW]);
1120 	if (ret < 0)
1121 		goto out;
1122 
1123 	/* Read-modify-write DRPW_SCRATCH_START register (see next state)
1124 	   to be used by DRPw FW. The RTRIM value will be added by the FW
1125 	   before taking DRPw out of reset */
1126 
1127 	ret = wlcore_read32(wl, WL12XX_DRPW_SCRATCH_START, &clk);
1128 	if (ret < 0)
1129 		goto out;
1130 
1131 	wl1271_debug(DEBUG_BOOT, "clk2 0x%x", clk);
1132 
1133 	if (wl->chip.id == CHIP_ID_128X_PG20)
1134 		clk |= ((selected_clock & 0x3) << 1) << 4;
1135 	else
1136 		clk |= (priv->ref_clock << 1) << 4;
1137 
1138 	ret = wlcore_write32(wl, WL12XX_DRPW_SCRATCH_START, clk);
1139 	if (ret < 0)
1140 		goto out;
1141 
1142 	ret = wlcore_set_partition(wl, &wl->ptable[PART_WORK]);
1143 	if (ret < 0)
1144 		goto out;
1145 
1146 	/* Disable interrupts */
1147 	ret = wlcore_write_reg(wl, REG_INTERRUPT_MASK, WL1271_ACX_INTR_ALL);
1148 	if (ret < 0)
1149 		goto out;
1150 
1151 	ret = wl1271_boot_soft_reset(wl);
1152 	if (ret < 0)
1153 		goto out;
1154 
1155 out:
1156 	return ret;
1157 }
1158 
1159 static int wl12xx_pre_upload(struct wl1271 *wl)
1160 {
1161 	u32 tmp;
1162 	u16 polarity;
1163 	int ret;
1164 
1165 	/* write firmware's last address (ie. it's length) to
1166 	 * ACX_EEPROMLESS_IND_REG */
1167 	wl1271_debug(DEBUG_BOOT, "ACX_EEPROMLESS_IND_REG");
1168 
1169 	ret = wlcore_write32(wl, WL12XX_EEPROMLESS_IND, WL12XX_EEPROMLESS_IND);
1170 	if (ret < 0)
1171 		goto out;
1172 
1173 	ret = wlcore_read_reg(wl, REG_CHIP_ID_B, &tmp);
1174 	if (ret < 0)
1175 		goto out;
1176 
1177 	wl1271_debug(DEBUG_BOOT, "chip id 0x%x", tmp);
1178 
1179 	/* 6. read the EEPROM parameters */
1180 	ret = wlcore_read32(wl, WL12XX_SCR_PAD2, &tmp);
1181 	if (ret < 0)
1182 		goto out;
1183 
1184 	/* WL1271: The reference driver skips steps 7 to 10 (jumps directly
1185 	 * to upload_fw) */
1186 
1187 	if (wl->chip.id == CHIP_ID_128X_PG20) {
1188 		ret = wl12xx_top_reg_write(wl, SDIO_IO_DS, HCI_IO_DS_6MA);
1189 		if (ret < 0)
1190 			goto out;
1191 	}
1192 
1193 	/* polarity must be set before the firmware is loaded */
1194 	ret = wl12xx_top_reg_read(wl, OCP_REG_POLARITY, &polarity);
1195 	if (ret < 0)
1196 		goto out;
1197 
1198 	/* We use HIGH polarity, so unset the LOW bit */
1199 	polarity &= ~POLARITY_LOW;
1200 	ret = wl12xx_top_reg_write(wl, OCP_REG_POLARITY, polarity);
1201 
1202 out:
1203 	return ret;
1204 }
1205 
1206 static int wl12xx_enable_interrupts(struct wl1271 *wl)
1207 {
1208 	int ret;
1209 
1210 	ret = wlcore_write_reg(wl, REG_INTERRUPT_MASK,
1211 			       WL12XX_ACX_ALL_EVENTS_VECTOR);
1212 	if (ret < 0)
1213 		goto out;
1214 
1215 	wlcore_enable_interrupts(wl);
1216 	ret = wlcore_write_reg(wl, REG_INTERRUPT_MASK,
1217 			       WL1271_ACX_INTR_ALL & ~(WL12XX_INTR_MASK));
1218 	if (ret < 0)
1219 		goto disable_interrupts;
1220 
1221 	ret = wlcore_write32(wl, WL12XX_HI_CFG, HI_CFG_DEF_VAL);
1222 	if (ret < 0)
1223 		goto disable_interrupts;
1224 
1225 	return ret;
1226 
1227 disable_interrupts:
1228 	wlcore_disable_interrupts(wl);
1229 
1230 out:
1231 	return ret;
1232 }
1233 
1234 static int wl12xx_boot(struct wl1271 *wl)
1235 {
1236 	int ret;
1237 
1238 	ret = wl12xx_pre_boot(wl);
1239 	if (ret < 0)
1240 		goto out;
1241 
1242 	ret = wlcore_boot_upload_nvs(wl);
1243 	if (ret < 0)
1244 		goto out;
1245 
1246 	ret = wl12xx_pre_upload(wl);
1247 	if (ret < 0)
1248 		goto out;
1249 
1250 	ret = wlcore_boot_upload_firmware(wl);
1251 	if (ret < 0)
1252 		goto out;
1253 
1254 	wl->event_mask = BSS_LOSE_EVENT_ID |
1255 		REGAINED_BSS_EVENT_ID |
1256 		SCAN_COMPLETE_EVENT_ID |
1257 		ROLE_STOP_COMPLETE_EVENT_ID |
1258 		RSSI_SNR_TRIGGER_0_EVENT_ID |
1259 		PSPOLL_DELIVERY_FAILURE_EVENT_ID |
1260 		SOFT_GEMINI_SENSE_EVENT_ID |
1261 		PERIODIC_SCAN_REPORT_EVENT_ID |
1262 		PERIODIC_SCAN_COMPLETE_EVENT_ID |
1263 		DUMMY_PACKET_EVENT_ID |
1264 		PEER_REMOVE_COMPLETE_EVENT_ID |
1265 		BA_SESSION_RX_CONSTRAINT_EVENT_ID |
1266 		REMAIN_ON_CHANNEL_COMPLETE_EVENT_ID |
1267 		INACTIVE_STA_EVENT_ID |
1268 		CHANNEL_SWITCH_COMPLETE_EVENT_ID;
1269 
1270 	wl->ap_event_mask = MAX_TX_RETRY_EVENT_ID;
1271 
1272 	ret = wlcore_boot_run_firmware(wl);
1273 	if (ret < 0)
1274 		goto out;
1275 
1276 	ret = wl12xx_enable_interrupts(wl);
1277 
1278 out:
1279 	return ret;
1280 }
1281 
1282 static int wl12xx_trigger_cmd(struct wl1271 *wl, int cmd_box_addr,
1283 			       void *buf, size_t len)
1284 {
1285 	int ret;
1286 
1287 	ret = wlcore_write(wl, cmd_box_addr, buf, len, false);
1288 	if (ret < 0)
1289 		return ret;
1290 
1291 	ret = wlcore_write_reg(wl, REG_INTERRUPT_TRIG, WL12XX_INTR_TRIG_CMD);
1292 
1293 	return ret;
1294 }
1295 
1296 static int wl12xx_ack_event(struct wl1271 *wl)
1297 {
1298 	return wlcore_write_reg(wl, REG_INTERRUPT_TRIG,
1299 				WL12XX_INTR_TRIG_EVENT_ACK);
1300 }
1301 
1302 static u32 wl12xx_calc_tx_blocks(struct wl1271 *wl, u32 len, u32 spare_blks)
1303 {
1304 	u32 blk_size = WL12XX_TX_HW_BLOCK_SIZE;
1305 	u32 align_len = wlcore_calc_packet_alignment(wl, len);
1306 
1307 	return (align_len + blk_size - 1) / blk_size + spare_blks;
1308 }
1309 
1310 static void
1311 wl12xx_set_tx_desc_blocks(struct wl1271 *wl, struct wl1271_tx_hw_descr *desc,
1312 			  u32 blks, u32 spare_blks)
1313 {
1314 	if (wl->chip.id == CHIP_ID_128X_PG20) {
1315 		desc->wl128x_mem.total_mem_blocks = blks;
1316 	} else {
1317 		desc->wl127x_mem.extra_blocks = spare_blks;
1318 		desc->wl127x_mem.total_mem_blocks = blks;
1319 	}
1320 }
1321 
1322 static void
1323 wl12xx_set_tx_desc_data_len(struct wl1271 *wl, struct wl1271_tx_hw_descr *desc,
1324 			    struct sk_buff *skb)
1325 {
1326 	u32 aligned_len = wlcore_calc_packet_alignment(wl, skb->len);
1327 
1328 	if (wl->chip.id == CHIP_ID_128X_PG20) {
1329 		desc->wl128x_mem.extra_bytes = aligned_len - skb->len;
1330 		desc->length = cpu_to_le16(aligned_len >> 2);
1331 
1332 		wl1271_debug(DEBUG_TX,
1333 			     "tx_fill_hdr: hlid: %d len: %d life: %d mem: %d extra: %d",
1334 			     desc->hlid,
1335 			     le16_to_cpu(desc->length),
1336 			     le16_to_cpu(desc->life_time),
1337 			     desc->wl128x_mem.total_mem_blocks,
1338 			     desc->wl128x_mem.extra_bytes);
1339 	} else {
1340 		/* calculate number of padding bytes */
1341 		int pad = aligned_len - skb->len;
1342 		desc->tx_attr |=
1343 			cpu_to_le16(pad << TX_HW_ATTR_OFST_LAST_WORD_PAD);
1344 
1345 		/* Store the aligned length in terms of words */
1346 		desc->length = cpu_to_le16(aligned_len >> 2);
1347 
1348 		wl1271_debug(DEBUG_TX,
1349 			     "tx_fill_hdr: pad: %d hlid: %d len: %d life: %d mem: %d",
1350 			     pad, desc->hlid,
1351 			     le16_to_cpu(desc->length),
1352 			     le16_to_cpu(desc->life_time),
1353 			     desc->wl127x_mem.total_mem_blocks);
1354 	}
1355 }
1356 
1357 static enum wl_rx_buf_align
1358 wl12xx_get_rx_buf_align(struct wl1271 *wl, u32 rx_desc)
1359 {
1360 	if (rx_desc & RX_BUF_UNALIGNED_PAYLOAD)
1361 		return WLCORE_RX_BUF_UNALIGNED;
1362 
1363 	return WLCORE_RX_BUF_ALIGNED;
1364 }
1365 
1366 static u32 wl12xx_get_rx_packet_len(struct wl1271 *wl, void *rx_data,
1367 				    u32 data_len)
1368 {
1369 	struct wl1271_rx_descriptor *desc = rx_data;
1370 
1371 	/* invalid packet */
1372 	if (data_len < sizeof(*desc) ||
1373 	    data_len < sizeof(*desc) + desc->pad_len)
1374 		return 0;
1375 
1376 	return data_len - sizeof(*desc) - desc->pad_len;
1377 }
1378 
1379 static int wl12xx_tx_delayed_compl(struct wl1271 *wl)
1380 {
1381 	if (wl->fw_status_1->tx_results_counter ==
1382 	    (wl->tx_results_count & 0xff))
1383 		return 0;
1384 
1385 	return wlcore_tx_complete(wl);
1386 }
1387 
1388 static int wl12xx_hw_init(struct wl1271 *wl)
1389 {
1390 	int ret;
1391 
1392 	if (wl->chip.id == CHIP_ID_128X_PG20) {
1393 		u32 host_cfg_bitmap = HOST_IF_CFG_RX_FIFO_ENABLE;
1394 
1395 		ret = wl128x_cmd_general_parms(wl);
1396 		if (ret < 0)
1397 			goto out;
1398 
1399 		/*
1400 		 * If we are in calibrator based auto detect then we got the FEM nr
1401 		 * in wl->fem_manuf. No need to continue further
1402 		 */
1403 		if (wl->plt_mode == PLT_FEM_DETECT)
1404 			goto out;
1405 
1406 		ret = wl128x_cmd_radio_parms(wl);
1407 		if (ret < 0)
1408 			goto out;
1409 
1410 		if (wl->quirks & WLCORE_QUIRK_TX_BLOCKSIZE_ALIGN)
1411 			/* Enable SDIO padding */
1412 			host_cfg_bitmap |= HOST_IF_CFG_TX_PAD_TO_SDIO_BLK;
1413 
1414 		/* Must be before wl1271_acx_init_mem_config() */
1415 		ret = wl1271_acx_host_if_cfg_bitmap(wl, host_cfg_bitmap);
1416 		if (ret < 0)
1417 			goto out;
1418 	} else {
1419 		ret = wl1271_cmd_general_parms(wl);
1420 		if (ret < 0)
1421 			goto out;
1422 
1423 		/*
1424 		 * If we are in calibrator based auto detect then we got the FEM nr
1425 		 * in wl->fem_manuf. No need to continue further
1426 		 */
1427 		if (wl->plt_mode == PLT_FEM_DETECT)
1428 			goto out;
1429 
1430 		ret = wl1271_cmd_radio_parms(wl);
1431 		if (ret < 0)
1432 			goto out;
1433 		ret = wl1271_cmd_ext_radio_parms(wl);
1434 		if (ret < 0)
1435 			goto out;
1436 	}
1437 out:
1438 	return ret;
1439 }
1440 
1441 static u32 wl12xx_sta_get_ap_rate_mask(struct wl1271 *wl,
1442 				       struct wl12xx_vif *wlvif)
1443 {
1444 	return wlvif->rate_set;
1445 }
1446 
1447 static void wl12xx_conf_init(struct wl1271 *wl)
1448 {
1449 	struct wl12xx_priv *priv = wl->priv;
1450 
1451 	/* apply driver default configuration */
1452 	memcpy(&wl->conf, &wl12xx_conf, sizeof(wl12xx_conf));
1453 
1454 	/* apply default private configuration */
1455 	memcpy(&priv->conf, &wl12xx_default_priv_conf, sizeof(priv->conf));
1456 }
1457 
1458 static bool wl12xx_mac_in_fuse(struct wl1271 *wl)
1459 {
1460 	bool supported = false;
1461 	u8 major, minor;
1462 
1463 	if (wl->chip.id == CHIP_ID_128X_PG20) {
1464 		major = WL128X_PG_GET_MAJOR(wl->hw_pg_ver);
1465 		minor = WL128X_PG_GET_MINOR(wl->hw_pg_ver);
1466 
1467 		/* in wl128x we have the MAC address if the PG is >= (2, 1) */
1468 		if (major > 2 || (major == 2 && minor >= 1))
1469 			supported = true;
1470 	} else {
1471 		major = WL127X_PG_GET_MAJOR(wl->hw_pg_ver);
1472 		minor = WL127X_PG_GET_MINOR(wl->hw_pg_ver);
1473 
1474 		/* in wl127x we have the MAC address if the PG is >= (3, 1) */
1475 		if (major == 3 && minor >= 1)
1476 			supported = true;
1477 	}
1478 
1479 	wl1271_debug(DEBUG_PROBE,
1480 		     "PG Ver major = %d minor = %d, MAC %s present",
1481 		     major, minor, supported ? "is" : "is not");
1482 
1483 	return supported;
1484 }
1485 
1486 static int wl12xx_get_fuse_mac(struct wl1271 *wl)
1487 {
1488 	u32 mac1, mac2;
1489 	int ret;
1490 
1491 	ret = wlcore_set_partition(wl, &wl->ptable[PART_DRPW]);
1492 	if (ret < 0)
1493 		goto out;
1494 
1495 	ret = wlcore_read32(wl, WL12XX_REG_FUSE_BD_ADDR_1, &mac1);
1496 	if (ret < 0)
1497 		goto out;
1498 
1499 	ret = wlcore_read32(wl, WL12XX_REG_FUSE_BD_ADDR_2, &mac2);
1500 	if (ret < 0)
1501 		goto out;
1502 
1503 	/* these are the two parts of the BD_ADDR */
1504 	wl->fuse_oui_addr = ((mac2 & 0xffff) << 8) +
1505 		((mac1 & 0xff000000) >> 24);
1506 	wl->fuse_nic_addr = mac1 & 0xffffff;
1507 
1508 	ret = wlcore_set_partition(wl, &wl->ptable[PART_DOWN]);
1509 
1510 out:
1511 	return ret;
1512 }
1513 
1514 static int wl12xx_get_pg_ver(struct wl1271 *wl, s8 *ver)
1515 {
1516 	u16 die_info;
1517 	int ret;
1518 
1519 	if (wl->chip.id == CHIP_ID_128X_PG20)
1520 		ret = wl12xx_top_reg_read(wl, WL128X_REG_FUSE_DATA_2_1,
1521 					  &die_info);
1522 	else
1523 		ret = wl12xx_top_reg_read(wl, WL127X_REG_FUSE_DATA_2_1,
1524 					  &die_info);
1525 
1526 	if (ret >= 0 && ver)
1527 		*ver = (s8)((die_info & PG_VER_MASK) >> PG_VER_OFFSET);
1528 
1529 	return ret;
1530 }
1531 
1532 static int wl12xx_get_mac(struct wl1271 *wl)
1533 {
1534 	if (wl12xx_mac_in_fuse(wl))
1535 		return wl12xx_get_fuse_mac(wl);
1536 
1537 	return 0;
1538 }
1539 
1540 static void wl12xx_set_tx_desc_csum(struct wl1271 *wl,
1541 				    struct wl1271_tx_hw_descr *desc,
1542 				    struct sk_buff *skb)
1543 {
1544 	desc->wl12xx_reserved = 0;
1545 }
1546 
1547 static int wl12xx_plt_init(struct wl1271 *wl)
1548 {
1549 	int ret;
1550 
1551 	ret = wl->ops->boot(wl);
1552 	if (ret < 0)
1553 		goto out;
1554 
1555 	ret = wl->ops->hw_init(wl);
1556 	if (ret < 0)
1557 		goto out_irq_disable;
1558 
1559 	/*
1560 	 * If we are in calibrator based auto detect then we got the FEM nr
1561 	 * in wl->fem_manuf. No need to continue further
1562 	 */
1563 	if (wl->plt_mode == PLT_FEM_DETECT)
1564 		goto out;
1565 
1566 	ret = wl1271_acx_init_mem_config(wl);
1567 	if (ret < 0)
1568 		goto out_irq_disable;
1569 
1570 	ret = wl12xx_acx_mem_cfg(wl);
1571 	if (ret < 0)
1572 		goto out_free_memmap;
1573 
1574 	/* Enable data path */
1575 	ret = wl1271_cmd_data_path(wl, 1);
1576 	if (ret < 0)
1577 		goto out_free_memmap;
1578 
1579 	/* Configure for CAM power saving (ie. always active) */
1580 	ret = wl1271_acx_sleep_auth(wl, WL1271_PSM_CAM);
1581 	if (ret < 0)
1582 		goto out_free_memmap;
1583 
1584 	/* configure PM */
1585 	ret = wl1271_acx_pm_config(wl);
1586 	if (ret < 0)
1587 		goto out_free_memmap;
1588 
1589 	goto out;
1590 
1591 out_free_memmap:
1592 	kfree(wl->target_mem_map);
1593 	wl->target_mem_map = NULL;
1594 
1595 out_irq_disable:
1596 	mutex_unlock(&wl->mutex);
1597 	/* Unlocking the mutex in the middle of handling is
1598 	   inherently unsafe. In this case we deem it safe to do,
1599 	   because we need to let any possibly pending IRQ out of
1600 	   the system (and while we are WL1271_STATE_OFF the IRQ
1601 	   work function will not do anything.) Also, any other
1602 	   possible concurrent operations will fail due to the
1603 	   current state, hence the wl1271 struct should be safe. */
1604 	wlcore_disable_interrupts(wl);
1605 	mutex_lock(&wl->mutex);
1606 out:
1607 	return ret;
1608 }
1609 
1610 static int wl12xx_get_spare_blocks(struct wl1271 *wl, bool is_gem)
1611 {
1612 	if (is_gem)
1613 		return WL12XX_TX_HW_BLOCK_GEM_SPARE;
1614 
1615 	return WL12XX_TX_HW_BLOCK_SPARE_DEFAULT;
1616 }
1617 
1618 static int wl12xx_set_key(struct wl1271 *wl, enum set_key_cmd cmd,
1619 			  struct ieee80211_vif *vif,
1620 			  struct ieee80211_sta *sta,
1621 			  struct ieee80211_key_conf *key_conf)
1622 {
1623 	return wlcore_set_key(wl, cmd, vif, sta, key_conf);
1624 }
1625 
1626 static int wl12xx_set_peer_cap(struct wl1271 *wl,
1627 			       struct ieee80211_sta_ht_cap *ht_cap,
1628 			       bool allow_ht_operation,
1629 			       u32 rate_set, u8 hlid)
1630 {
1631 	return wl1271_acx_set_ht_capabilities(wl, ht_cap, allow_ht_operation,
1632 					      hlid);
1633 }
1634 
1635 static bool wl12xx_lnk_high_prio(struct wl1271 *wl, u8 hlid,
1636 				 struct wl1271_link *lnk)
1637 {
1638 	u8 thold;
1639 
1640 	if (test_bit(hlid, (unsigned long *)&wl->fw_fast_lnk_map))
1641 		thold = wl->conf.tx.fast_link_thold;
1642 	else
1643 		thold = wl->conf.tx.slow_link_thold;
1644 
1645 	return lnk->allocated_pkts < thold;
1646 }
1647 
1648 static bool wl12xx_lnk_low_prio(struct wl1271 *wl, u8 hlid,
1649 				struct wl1271_link *lnk)
1650 {
1651 	/* any link is good for low priority */
1652 	return true;
1653 }
1654 
1655 static u32 wl12xx_convert_hwaddr(struct wl1271 *wl, u32 hwaddr)
1656 {
1657 	return hwaddr << 5;
1658 }
1659 
1660 static int wl12xx_setup(struct wl1271 *wl);
1661 
1662 static struct wlcore_ops wl12xx_ops = {
1663 	.setup			= wl12xx_setup,
1664 	.identify_chip		= wl12xx_identify_chip,
1665 	.boot			= wl12xx_boot,
1666 	.plt_init		= wl12xx_plt_init,
1667 	.trigger_cmd		= wl12xx_trigger_cmd,
1668 	.ack_event		= wl12xx_ack_event,
1669 	.wait_for_event		= wl12xx_wait_for_event,
1670 	.process_mailbox_events	= wl12xx_process_mailbox_events,
1671 	.calc_tx_blocks		= wl12xx_calc_tx_blocks,
1672 	.set_tx_desc_blocks	= wl12xx_set_tx_desc_blocks,
1673 	.set_tx_desc_data_len	= wl12xx_set_tx_desc_data_len,
1674 	.get_rx_buf_align	= wl12xx_get_rx_buf_align,
1675 	.get_rx_packet_len	= wl12xx_get_rx_packet_len,
1676 	.tx_immediate_compl	= NULL,
1677 	.tx_delayed_compl	= wl12xx_tx_delayed_compl,
1678 	.hw_init		= wl12xx_hw_init,
1679 	.init_vif		= NULL,
1680 	.sta_get_ap_rate_mask	= wl12xx_sta_get_ap_rate_mask,
1681 	.get_pg_ver		= wl12xx_get_pg_ver,
1682 	.get_mac		= wl12xx_get_mac,
1683 	.set_tx_desc_csum	= wl12xx_set_tx_desc_csum,
1684 	.set_rx_csum		= NULL,
1685 	.ap_get_mimo_wide_rate_mask = NULL,
1686 	.debugfs_init		= wl12xx_debugfs_add_files,
1687 	.scan_start		= wl12xx_scan_start,
1688 	.scan_stop		= wl12xx_scan_stop,
1689 	.sched_scan_start	= wl12xx_sched_scan_start,
1690 	.sched_scan_stop	= wl12xx_scan_sched_scan_stop,
1691 	.get_spare_blocks	= wl12xx_get_spare_blocks,
1692 	.set_key		= wl12xx_set_key,
1693 	.channel_switch		= wl12xx_cmd_channel_switch,
1694 	.pre_pkt_send		= NULL,
1695 	.set_peer_cap		= wl12xx_set_peer_cap,
1696 	.convert_hwaddr		= wl12xx_convert_hwaddr,
1697 	.lnk_high_prio		= wl12xx_lnk_high_prio,
1698 	.lnk_low_prio		= wl12xx_lnk_low_prio,
1699 };
1700 
1701 static struct ieee80211_sta_ht_cap wl12xx_ht_cap = {
1702 	.cap = IEEE80211_HT_CAP_GRN_FLD | IEEE80211_HT_CAP_SGI_20 |
1703 	       (1 << IEEE80211_HT_CAP_RX_STBC_SHIFT),
1704 	.ht_supported = true,
1705 	.ampdu_factor = IEEE80211_HT_MAX_AMPDU_8K,
1706 	.ampdu_density = IEEE80211_HT_MPDU_DENSITY_8,
1707 	.mcs = {
1708 		.rx_mask = { 0xff, 0, 0, 0, 0, 0, 0, 0, 0, 0, },
1709 		.rx_highest = cpu_to_le16(72),
1710 		.tx_params = IEEE80211_HT_MCS_TX_DEFINED,
1711 		},
1712 };
1713 
1714 static int wl12xx_setup(struct wl1271 *wl)
1715 {
1716 	struct wl12xx_priv *priv = wl->priv;
1717 	struct wlcore_platdev_data *pdev_data = dev_get_platdata(&wl->pdev->dev);
1718 	struct wl12xx_platform_data *pdata = pdev_data->pdata;
1719 
1720 	wl->rtable = wl12xx_rtable;
1721 	wl->num_tx_desc = WL12XX_NUM_TX_DESCRIPTORS;
1722 	wl->num_rx_desc = WL12XX_NUM_RX_DESCRIPTORS;
1723 	wl->num_channels = 1;
1724 	wl->num_mac_addr = WL12XX_NUM_MAC_ADDRESSES;
1725 	wl->band_rate_to_idx = wl12xx_band_rate_to_idx;
1726 	wl->hw_tx_rate_tbl_size = WL12XX_CONF_HW_RXTX_RATE_MAX;
1727 	wl->hw_min_ht_rate = WL12XX_CONF_HW_RXTX_RATE_MCS0;
1728 	wl->fw_status_priv_len = 0;
1729 	wl->stats.fw_stats_len = sizeof(struct wl12xx_acx_statistics);
1730 	wlcore_set_ht_cap(wl, IEEE80211_BAND_2GHZ, &wl12xx_ht_cap);
1731 	wlcore_set_ht_cap(wl, IEEE80211_BAND_5GHZ, &wl12xx_ht_cap);
1732 	wl12xx_conf_init(wl);
1733 
1734 	if (!fref_param) {
1735 		priv->ref_clock = pdata->board_ref_clock;
1736 	} else {
1737 		if (!strcmp(fref_param, "19.2"))
1738 			priv->ref_clock = WL12XX_REFCLOCK_19;
1739 		else if (!strcmp(fref_param, "26"))
1740 			priv->ref_clock = WL12XX_REFCLOCK_26;
1741 		else if (!strcmp(fref_param, "26x"))
1742 			priv->ref_clock = WL12XX_REFCLOCK_26_XTAL;
1743 		else if (!strcmp(fref_param, "38.4"))
1744 			priv->ref_clock = WL12XX_REFCLOCK_38;
1745 		else if (!strcmp(fref_param, "38.4x"))
1746 			priv->ref_clock = WL12XX_REFCLOCK_38_XTAL;
1747 		else if (!strcmp(fref_param, "52"))
1748 			priv->ref_clock = WL12XX_REFCLOCK_52;
1749 		else
1750 			wl1271_error("Invalid fref parameter %s", fref_param);
1751 	}
1752 
1753 	if (!tcxo_param) {
1754 		priv->tcxo_clock = pdata->board_tcxo_clock;
1755 	} else {
1756 		if (!strcmp(tcxo_param, "19.2"))
1757 			priv->tcxo_clock = WL12XX_TCXOCLOCK_19_2;
1758 		else if (!strcmp(tcxo_param, "26"))
1759 			priv->tcxo_clock = WL12XX_TCXOCLOCK_26;
1760 		else if (!strcmp(tcxo_param, "38.4"))
1761 			priv->tcxo_clock = WL12XX_TCXOCLOCK_38_4;
1762 		else if (!strcmp(tcxo_param, "52"))
1763 			priv->tcxo_clock = WL12XX_TCXOCLOCK_52;
1764 		else if (!strcmp(tcxo_param, "16.368"))
1765 			priv->tcxo_clock = WL12XX_TCXOCLOCK_16_368;
1766 		else if (!strcmp(tcxo_param, "32.736"))
1767 			priv->tcxo_clock = WL12XX_TCXOCLOCK_32_736;
1768 		else if (!strcmp(tcxo_param, "16.8"))
1769 			priv->tcxo_clock = WL12XX_TCXOCLOCK_16_8;
1770 		else if (!strcmp(tcxo_param, "33.6"))
1771 			priv->tcxo_clock = WL12XX_TCXOCLOCK_33_6;
1772 		else
1773 			wl1271_error("Invalid tcxo parameter %s", tcxo_param);
1774 	}
1775 
1776 	priv->rx_mem_addr = kmalloc(sizeof(*priv->rx_mem_addr), GFP_KERNEL);
1777 	if (!priv->rx_mem_addr)
1778 		return -ENOMEM;
1779 
1780 	return 0;
1781 }
1782 
1783 static int wl12xx_probe(struct platform_device *pdev)
1784 {
1785 	struct wl1271 *wl;
1786 	struct ieee80211_hw *hw;
1787 	int ret;
1788 
1789 	hw = wlcore_alloc_hw(sizeof(struct wl12xx_priv),
1790 			     WL12XX_AGGR_BUFFER_SIZE,
1791 			     sizeof(struct wl12xx_event_mailbox));
1792 	if (IS_ERR(hw)) {
1793 		wl1271_error("can't allocate hw");
1794 		ret = PTR_ERR(hw);
1795 		goto out;
1796 	}
1797 
1798 	wl = hw->priv;
1799 	wl->ops = &wl12xx_ops;
1800 	wl->ptable = wl12xx_ptable;
1801 	ret = wlcore_probe(wl, pdev);
1802 	if (ret)
1803 		goto out_free;
1804 
1805 	return ret;
1806 
1807 out_free:
1808 	wlcore_free_hw(wl);
1809 out:
1810 	return ret;
1811 }
1812 
1813 static int wl12xx_remove(struct platform_device *pdev)
1814 {
1815 	struct wl1271 *wl = platform_get_drvdata(pdev);
1816 	struct wl12xx_priv *priv;
1817 
1818 	if (!wl)
1819 		goto out;
1820 	priv = wl->priv;
1821 
1822 	kfree(priv->rx_mem_addr);
1823 
1824 out:
1825 	return wlcore_remove(pdev);
1826 }
1827 
1828 static const struct platform_device_id wl12xx_id_table[] = {
1829 	{ "wl12xx", 0 },
1830 	{  } /* Terminating Entry */
1831 };
1832 MODULE_DEVICE_TABLE(platform, wl12xx_id_table);
1833 
1834 static struct platform_driver wl12xx_driver = {
1835 	.probe		= wl12xx_probe,
1836 	.remove		= wl12xx_remove,
1837 	.id_table	= wl12xx_id_table,
1838 	.driver = {
1839 		.name	= "wl12xx_driver",
1840 		.owner	= THIS_MODULE,
1841 	}
1842 };
1843 
1844 module_platform_driver(wl12xx_driver);
1845 
1846 module_param_named(fref, fref_param, charp, 0);
1847 MODULE_PARM_DESC(fref, "FREF clock: 19.2, 26, 26x, 38.4, 38.4x, 52");
1848 
1849 module_param_named(tcxo, tcxo_param, charp, 0);
1850 MODULE_PARM_DESC(tcxo,
1851 		 "TCXO clock: 19.2, 26, 38.4, 52, 16.368, 32.736, 16.8, 33.6");
1852 
1853 MODULE_LICENSE("GPL v2");
1854 MODULE_AUTHOR("Luciano Coelho <coelho@ti.com>");
1855 MODULE_FIRMWARE(WL127X_FW_NAME_SINGLE);
1856 MODULE_FIRMWARE(WL127X_FW_NAME_MULTI);
1857 MODULE_FIRMWARE(WL127X_PLT_FW_NAME);
1858 MODULE_FIRMWARE(WL128X_FW_NAME_SINGLE);
1859 MODULE_FIRMWARE(WL128X_FW_NAME_MULTI);
1860 MODULE_FIRMWARE(WL128X_PLT_FW_NAME);
1861