1 /*
2 * This file is part of wlcore
3 *
4 * Copyright (C) 2008-2010 Nokia Corporation
5 * Copyright (C) 2011-2013 Texas Instruments Inc.
6 *
7 * This program is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * version 2 as published by the Free Software Foundation.
10 *
11 * This program is distributed in the hope that it will be useful, but
12 * WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
19 * 02110-1301 USA
20 *
21 */
22
23 #include <linux/module.h>
24 #include <linux/firmware.h>
25 #include <linux/etherdevice.h>
26 #include <linux/vmalloc.h>
27 #include <linux/interrupt.h>
28 #include <linux/irq.h>
29 #include <linux/pm_runtime.h>
30
31 #include "wlcore.h"
32 #include "debug.h"
33 #include "wl12xx_80211.h"
34 #include "io.h"
35 #include "tx.h"
36 #include "ps.h"
37 #include "init.h"
38 #include "debugfs.h"
39 #include "testmode.h"
40 #include "vendor_cmd.h"
41 #include "scan.h"
42 #include "hw_ops.h"
43 #include "sysfs.h"
44
45 #define WL1271_BOOT_RETRIES 3
46 #define WL1271_SUSPEND_SLEEP 100
47 #define WL1271_WAKEUP_TIMEOUT 500
48
49 static char *fwlog_param;
50 static int fwlog_mem_blocks = -1;
51 static int bug_on_recovery = -1;
52 static int no_recovery = -1;
53
54 static void __wl1271_op_remove_interface(struct wl1271 *wl,
55 struct ieee80211_vif *vif,
56 bool reset_tx_queues);
57 static void wlcore_op_stop_locked(struct wl1271 *wl);
58 static void wl1271_free_ap_keys(struct wl1271 *wl, struct wl12xx_vif *wlvif);
59
wl12xx_set_authorized(struct wl1271 * wl,struct wl12xx_vif * wlvif)60 static int wl12xx_set_authorized(struct wl1271 *wl, struct wl12xx_vif *wlvif)
61 {
62 int ret;
63
64 if (WARN_ON(wlvif->bss_type != BSS_TYPE_STA_BSS))
65 return -EINVAL;
66
67 if (!test_bit(WLVIF_FLAG_STA_ASSOCIATED, &wlvif->flags))
68 return 0;
69
70 if (test_and_set_bit(WLVIF_FLAG_STA_STATE_SENT, &wlvif->flags))
71 return 0;
72
73 ret = wl12xx_cmd_set_peer_state(wl, wlvif, wlvif->sta.hlid);
74 if (ret < 0)
75 return ret;
76
77 wl1271_info("Association completed.");
78 return 0;
79 }
80
wl1271_reg_notify(struct wiphy * wiphy,struct regulatory_request * request)81 static void wl1271_reg_notify(struct wiphy *wiphy,
82 struct regulatory_request *request)
83 {
84 struct ieee80211_hw *hw = wiphy_to_ieee80211_hw(wiphy);
85 struct wl1271 *wl = hw->priv;
86
87 /* copy the current dfs region */
88 if (request)
89 wl->dfs_region = request->dfs_region;
90
91 wlcore_regdomain_config(wl);
92 }
93
wl1271_set_rx_streaming(struct wl1271 * wl,struct wl12xx_vif * wlvif,bool enable)94 static int wl1271_set_rx_streaming(struct wl1271 *wl, struct wl12xx_vif *wlvif,
95 bool enable)
96 {
97 int ret = 0;
98
99 /* we should hold wl->mutex */
100 ret = wl1271_acx_ps_rx_streaming(wl, wlvif, enable);
101 if (ret < 0)
102 goto out;
103
104 if (enable)
105 set_bit(WLVIF_FLAG_RX_STREAMING_STARTED, &wlvif->flags);
106 else
107 clear_bit(WLVIF_FLAG_RX_STREAMING_STARTED, &wlvif->flags);
108 out:
109 return ret;
110 }
111
112 /*
113 * this function is being called when the rx_streaming interval
114 * has beed changed or rx_streaming should be disabled
115 */
wl1271_recalc_rx_streaming(struct wl1271 * wl,struct wl12xx_vif * wlvif)116 int wl1271_recalc_rx_streaming(struct wl1271 *wl, struct wl12xx_vif *wlvif)
117 {
118 int ret = 0;
119 int period = wl->conf.rx_streaming.interval;
120
121 /* don't reconfigure if rx_streaming is disabled */
122 if (!test_bit(WLVIF_FLAG_RX_STREAMING_STARTED, &wlvif->flags))
123 goto out;
124
125 /* reconfigure/disable according to new streaming_period */
126 if (period &&
127 test_bit(WLVIF_FLAG_STA_ASSOCIATED, &wlvif->flags) &&
128 (wl->conf.rx_streaming.always ||
129 test_bit(WL1271_FLAG_SOFT_GEMINI, &wl->flags)))
130 ret = wl1271_set_rx_streaming(wl, wlvif, true);
131 else {
132 ret = wl1271_set_rx_streaming(wl, wlvif, false);
133 /* don't cancel_work_sync since we might deadlock */
134 del_timer_sync(&wlvif->rx_streaming_timer);
135 }
136 out:
137 return ret;
138 }
139
wl1271_rx_streaming_enable_work(struct work_struct * work)140 static void wl1271_rx_streaming_enable_work(struct work_struct *work)
141 {
142 int ret;
143 struct wl12xx_vif *wlvif = container_of(work, struct wl12xx_vif,
144 rx_streaming_enable_work);
145 struct wl1271 *wl = wlvif->wl;
146
147 mutex_lock(&wl->mutex);
148
149 if (test_bit(WLVIF_FLAG_RX_STREAMING_STARTED, &wlvif->flags) ||
150 !test_bit(WLVIF_FLAG_STA_ASSOCIATED, &wlvif->flags) ||
151 (!wl->conf.rx_streaming.always &&
152 !test_bit(WL1271_FLAG_SOFT_GEMINI, &wl->flags)))
153 goto out;
154
155 if (!wl->conf.rx_streaming.interval)
156 goto out;
157
158 ret = pm_runtime_get_sync(wl->dev);
159 if (ret < 0) {
160 pm_runtime_put_noidle(wl->dev);
161 goto out;
162 }
163
164 ret = wl1271_set_rx_streaming(wl, wlvif, true);
165 if (ret < 0)
166 goto out_sleep;
167
168 /* stop it after some time of inactivity */
169 mod_timer(&wlvif->rx_streaming_timer,
170 jiffies + msecs_to_jiffies(wl->conf.rx_streaming.duration));
171
172 out_sleep:
173 pm_runtime_mark_last_busy(wl->dev);
174 pm_runtime_put_autosuspend(wl->dev);
175 out:
176 mutex_unlock(&wl->mutex);
177 }
178
wl1271_rx_streaming_disable_work(struct work_struct * work)179 static void wl1271_rx_streaming_disable_work(struct work_struct *work)
180 {
181 int ret;
182 struct wl12xx_vif *wlvif = container_of(work, struct wl12xx_vif,
183 rx_streaming_disable_work);
184 struct wl1271 *wl = wlvif->wl;
185
186 mutex_lock(&wl->mutex);
187
188 if (!test_bit(WLVIF_FLAG_RX_STREAMING_STARTED, &wlvif->flags))
189 goto out;
190
191 ret = pm_runtime_get_sync(wl->dev);
192 if (ret < 0) {
193 pm_runtime_put_noidle(wl->dev);
194 goto out;
195 }
196
197 ret = wl1271_set_rx_streaming(wl, wlvif, false);
198 if (ret)
199 goto out_sleep;
200
201 out_sleep:
202 pm_runtime_mark_last_busy(wl->dev);
203 pm_runtime_put_autosuspend(wl->dev);
204 out:
205 mutex_unlock(&wl->mutex);
206 }
207
wl1271_rx_streaming_timer(struct timer_list * t)208 static void wl1271_rx_streaming_timer(struct timer_list *t)
209 {
210 struct wl12xx_vif *wlvif = from_timer(wlvif, t, rx_streaming_timer);
211 struct wl1271 *wl = wlvif->wl;
212 ieee80211_queue_work(wl->hw, &wlvif->rx_streaming_disable_work);
213 }
214
215 /* wl->mutex must be taken */
wl12xx_rearm_tx_watchdog_locked(struct wl1271 * wl)216 void wl12xx_rearm_tx_watchdog_locked(struct wl1271 *wl)
217 {
218 /* if the watchdog is not armed, don't do anything */
219 if (wl->tx_allocated_blocks == 0)
220 return;
221
222 cancel_delayed_work(&wl->tx_watchdog_work);
223 ieee80211_queue_delayed_work(wl->hw, &wl->tx_watchdog_work,
224 msecs_to_jiffies(wl->conf.tx.tx_watchdog_timeout));
225 }
226
wlcore_rc_update_work(struct work_struct * work)227 static void wlcore_rc_update_work(struct work_struct *work)
228 {
229 int ret;
230 struct wl12xx_vif *wlvif = container_of(work, struct wl12xx_vif,
231 rc_update_work);
232 struct wl1271 *wl = wlvif->wl;
233 struct ieee80211_vif *vif = wl12xx_wlvif_to_vif(wlvif);
234
235 mutex_lock(&wl->mutex);
236
237 if (unlikely(wl->state != WLCORE_STATE_ON))
238 goto out;
239
240 ret = pm_runtime_get_sync(wl->dev);
241 if (ret < 0) {
242 pm_runtime_put_noidle(wl->dev);
243 goto out;
244 }
245
246 if (ieee80211_vif_is_mesh(vif)) {
247 ret = wl1271_acx_set_ht_capabilities(wl, &wlvif->rc_ht_cap,
248 true, wlvif->sta.hlid);
249 if (ret < 0)
250 goto out_sleep;
251 } else {
252 wlcore_hw_sta_rc_update(wl, wlvif);
253 }
254
255 out_sleep:
256 pm_runtime_mark_last_busy(wl->dev);
257 pm_runtime_put_autosuspend(wl->dev);
258 out:
259 mutex_unlock(&wl->mutex);
260 }
261
wl12xx_tx_watchdog_work(struct work_struct * work)262 static void wl12xx_tx_watchdog_work(struct work_struct *work)
263 {
264 struct delayed_work *dwork;
265 struct wl1271 *wl;
266
267 dwork = to_delayed_work(work);
268 wl = container_of(dwork, struct wl1271, tx_watchdog_work);
269
270 mutex_lock(&wl->mutex);
271
272 if (unlikely(wl->state != WLCORE_STATE_ON))
273 goto out;
274
275 /* Tx went out in the meantime - everything is ok */
276 if (unlikely(wl->tx_allocated_blocks == 0))
277 goto out;
278
279 /*
280 * if a ROC is in progress, we might not have any Tx for a long
281 * time (e.g. pending Tx on the non-ROC channels)
282 */
283 if (find_first_bit(wl->roc_map, WL12XX_MAX_ROLES) < WL12XX_MAX_ROLES) {
284 wl1271_debug(DEBUG_TX, "No Tx (in FW) for %d ms due to ROC",
285 wl->conf.tx.tx_watchdog_timeout);
286 wl12xx_rearm_tx_watchdog_locked(wl);
287 goto out;
288 }
289
290 /*
291 * if a scan is in progress, we might not have any Tx for a long
292 * time
293 */
294 if (wl->scan.state != WL1271_SCAN_STATE_IDLE) {
295 wl1271_debug(DEBUG_TX, "No Tx (in FW) for %d ms due to scan",
296 wl->conf.tx.tx_watchdog_timeout);
297 wl12xx_rearm_tx_watchdog_locked(wl);
298 goto out;
299 }
300
301 /*
302 * AP might cache a frame for a long time for a sleeping station,
303 * so rearm the timer if there's an AP interface with stations. If
304 * Tx is genuinely stuck we will most hopefully discover it when all
305 * stations are removed due to inactivity.
306 */
307 if (wl->active_sta_count) {
308 wl1271_debug(DEBUG_TX, "No Tx (in FW) for %d ms. AP has "
309 " %d stations",
310 wl->conf.tx.tx_watchdog_timeout,
311 wl->active_sta_count);
312 wl12xx_rearm_tx_watchdog_locked(wl);
313 goto out;
314 }
315
316 wl1271_error("Tx stuck (in FW) for %d ms. Starting recovery",
317 wl->conf.tx.tx_watchdog_timeout);
318 wl12xx_queue_recovery_work(wl);
319
320 out:
321 mutex_unlock(&wl->mutex);
322 }
323
wlcore_adjust_conf(struct wl1271 * wl)324 static void wlcore_adjust_conf(struct wl1271 *wl)
325 {
326
327 if (fwlog_param) {
328 if (!strcmp(fwlog_param, "continuous")) {
329 wl->conf.fwlog.mode = WL12XX_FWLOG_CONTINUOUS;
330 wl->conf.fwlog.output = WL12XX_FWLOG_OUTPUT_HOST;
331 } else if (!strcmp(fwlog_param, "dbgpins")) {
332 wl->conf.fwlog.mode = WL12XX_FWLOG_CONTINUOUS;
333 wl->conf.fwlog.output = WL12XX_FWLOG_OUTPUT_DBG_PINS;
334 } else if (!strcmp(fwlog_param, "disable")) {
335 wl->conf.fwlog.mem_blocks = 0;
336 wl->conf.fwlog.output = WL12XX_FWLOG_OUTPUT_NONE;
337 } else {
338 wl1271_error("Unknown fwlog parameter %s", fwlog_param);
339 }
340 }
341
342 if (bug_on_recovery != -1)
343 wl->conf.recovery.bug_on_recovery = (u8) bug_on_recovery;
344
345 if (no_recovery != -1)
346 wl->conf.recovery.no_recovery = (u8) no_recovery;
347 }
348
wl12xx_irq_ps_regulate_link(struct wl1271 * wl,struct wl12xx_vif * wlvif,u8 hlid,u8 tx_pkts)349 static void wl12xx_irq_ps_regulate_link(struct wl1271 *wl,
350 struct wl12xx_vif *wlvif,
351 u8 hlid, u8 tx_pkts)
352 {
353 bool fw_ps;
354
355 fw_ps = test_bit(hlid, &wl->ap_fw_ps_map);
356
357 /*
358 * Wake up from high level PS if the STA is asleep with too little
359 * packets in FW or if the STA is awake.
360 */
361 if (!fw_ps || tx_pkts < WL1271_PS_STA_MAX_PACKETS)
362 wl12xx_ps_link_end(wl, wlvif, hlid);
363
364 /*
365 * Start high-level PS if the STA is asleep with enough blocks in FW.
366 * Make an exception if this is the only connected link. In this
367 * case FW-memory congestion is less of a problem.
368 * Note that a single connected STA means 2*ap_count + 1 active links,
369 * since we must account for the global and broadcast AP links
370 * for each AP. The "fw_ps" check assures us the other link is a STA
371 * connected to the AP. Otherwise the FW would not set the PSM bit.
372 */
373 else if (wl->active_link_count > (wl->ap_count*2 + 1) && fw_ps &&
374 tx_pkts >= WL1271_PS_STA_MAX_PACKETS)
375 wl12xx_ps_link_start(wl, wlvif, hlid, true);
376 }
377
wl12xx_irq_update_links_status(struct wl1271 * wl,struct wl12xx_vif * wlvif,struct wl_fw_status * status)378 static void wl12xx_irq_update_links_status(struct wl1271 *wl,
379 struct wl12xx_vif *wlvif,
380 struct wl_fw_status *status)
381 {
382 unsigned long cur_fw_ps_map;
383 u8 hlid;
384
385 cur_fw_ps_map = status->link_ps_bitmap;
386 if (wl->ap_fw_ps_map != cur_fw_ps_map) {
387 wl1271_debug(DEBUG_PSM,
388 "link ps prev 0x%lx cur 0x%lx changed 0x%lx",
389 wl->ap_fw_ps_map, cur_fw_ps_map,
390 wl->ap_fw_ps_map ^ cur_fw_ps_map);
391
392 wl->ap_fw_ps_map = cur_fw_ps_map;
393 }
394
395 for_each_set_bit(hlid, wlvif->ap.sta_hlid_map, wl->num_links)
396 wl12xx_irq_ps_regulate_link(wl, wlvif, hlid,
397 wl->links[hlid].allocated_pkts);
398 }
399
wlcore_fw_status(struct wl1271 * wl,struct wl_fw_status * status)400 static int wlcore_fw_status(struct wl1271 *wl, struct wl_fw_status *status)
401 {
402 struct wl12xx_vif *wlvif;
403 u32 old_tx_blk_count = wl->tx_blocks_available;
404 int avail, freed_blocks;
405 int i;
406 int ret;
407 struct wl1271_link *lnk;
408
409 ret = wlcore_raw_read_data(wl, REG_RAW_FW_STATUS_ADDR,
410 wl->raw_fw_status,
411 wl->fw_status_len, false);
412 if (ret < 0)
413 return ret;
414
415 wlcore_hw_convert_fw_status(wl, wl->raw_fw_status, wl->fw_status);
416
417 wl1271_debug(DEBUG_IRQ, "intr: 0x%x (fw_rx_counter = %d, "
418 "drv_rx_counter = %d, tx_results_counter = %d)",
419 status->intr,
420 status->fw_rx_counter,
421 status->drv_rx_counter,
422 status->tx_results_counter);
423
424 for (i = 0; i < NUM_TX_QUEUES; i++) {
425 /* prevent wrap-around in freed-packets counter */
426 wl->tx_allocated_pkts[i] -=
427 (status->counters.tx_released_pkts[i] -
428 wl->tx_pkts_freed[i]) & 0xff;
429
430 wl->tx_pkts_freed[i] = status->counters.tx_released_pkts[i];
431 }
432
433
434 for_each_set_bit(i, wl->links_map, wl->num_links) {
435 u8 diff;
436 lnk = &wl->links[i];
437
438 /* prevent wrap-around in freed-packets counter */
439 diff = (status->counters.tx_lnk_free_pkts[i] -
440 lnk->prev_freed_pkts) & 0xff;
441
442 if (diff == 0)
443 continue;
444
445 lnk->allocated_pkts -= diff;
446 lnk->prev_freed_pkts = status->counters.tx_lnk_free_pkts[i];
447
448 /* accumulate the prev_freed_pkts counter */
449 lnk->total_freed_pkts += diff;
450 }
451
452 /* prevent wrap-around in total blocks counter */
453 if (likely(wl->tx_blocks_freed <= status->total_released_blks))
454 freed_blocks = status->total_released_blks -
455 wl->tx_blocks_freed;
456 else
457 freed_blocks = 0x100000000LL - wl->tx_blocks_freed +
458 status->total_released_blks;
459
460 wl->tx_blocks_freed = status->total_released_blks;
461
462 wl->tx_allocated_blocks -= freed_blocks;
463
464 /*
465 * If the FW freed some blocks:
466 * If we still have allocated blocks - re-arm the timer, Tx is
467 * not stuck. Otherwise, cancel the timer (no Tx currently).
468 */
469 if (freed_blocks) {
470 if (wl->tx_allocated_blocks)
471 wl12xx_rearm_tx_watchdog_locked(wl);
472 else
473 cancel_delayed_work(&wl->tx_watchdog_work);
474 }
475
476 avail = status->tx_total - wl->tx_allocated_blocks;
477
478 /*
479 * The FW might change the total number of TX memblocks before
480 * we get a notification about blocks being released. Thus, the
481 * available blocks calculation might yield a temporary result
482 * which is lower than the actual available blocks. Keeping in
483 * mind that only blocks that were allocated can be moved from
484 * TX to RX, tx_blocks_available should never decrease here.
485 */
486 wl->tx_blocks_available = max((int)wl->tx_blocks_available,
487 avail);
488
489 /* if more blocks are available now, tx work can be scheduled */
490 if (wl->tx_blocks_available > old_tx_blk_count)
491 clear_bit(WL1271_FLAG_FW_TX_BUSY, &wl->flags);
492
493 /* for AP update num of allocated TX blocks per link and ps status */
494 wl12xx_for_each_wlvif_ap(wl, wlvif) {
495 wl12xx_irq_update_links_status(wl, wlvif, status);
496 }
497
498 /* update the host-chipset time offset */
499 wl->time_offset = (ktime_get_boot_ns() >> 10) -
500 (s64)(status->fw_localtime);
501
502 wl->fw_fast_lnk_map = status->link_fast_bitmap;
503
504 return 0;
505 }
506
wl1271_flush_deferred_work(struct wl1271 * wl)507 static void wl1271_flush_deferred_work(struct wl1271 *wl)
508 {
509 struct sk_buff *skb;
510
511 /* Pass all received frames to the network stack */
512 while ((skb = skb_dequeue(&wl->deferred_rx_queue)))
513 ieee80211_rx_ni(wl->hw, skb);
514
515 /* Return sent skbs to the network stack */
516 while ((skb = skb_dequeue(&wl->deferred_tx_queue)))
517 ieee80211_tx_status_ni(wl->hw, skb);
518 }
519
wl1271_netstack_work(struct work_struct * work)520 static void wl1271_netstack_work(struct work_struct *work)
521 {
522 struct wl1271 *wl =
523 container_of(work, struct wl1271, netstack_work);
524
525 do {
526 wl1271_flush_deferred_work(wl);
527 } while (skb_queue_len(&wl->deferred_rx_queue));
528 }
529
530 #define WL1271_IRQ_MAX_LOOPS 256
531
wlcore_irq_locked(struct wl1271 * wl)532 static int wlcore_irq_locked(struct wl1271 *wl)
533 {
534 int ret = 0;
535 u32 intr;
536 int loopcount = WL1271_IRQ_MAX_LOOPS;
537 bool done = false;
538 unsigned int defer_count;
539 unsigned long flags;
540
541 /*
542 * In case edge triggered interrupt must be used, we cannot iterate
543 * more than once without introducing race conditions with the hardirq.
544 */
545 if (wl->irq_flags & (IRQF_TRIGGER_RISING | IRQF_TRIGGER_FALLING))
546 loopcount = 1;
547
548 wl1271_debug(DEBUG_IRQ, "IRQ work");
549
550 if (unlikely(wl->state != WLCORE_STATE_ON))
551 goto out;
552
553 ret = pm_runtime_get_sync(wl->dev);
554 if (ret < 0) {
555 pm_runtime_put_noidle(wl->dev);
556 goto out;
557 }
558
559 while (!done && loopcount--) {
560 /*
561 * In order to avoid a race with the hardirq, clear the flag
562 * before acknowledging the chip.
563 */
564 clear_bit(WL1271_FLAG_IRQ_RUNNING, &wl->flags);
565 smp_mb__after_atomic();
566
567 ret = wlcore_fw_status(wl, wl->fw_status);
568 if (ret < 0)
569 goto out;
570
571 wlcore_hw_tx_immediate_compl(wl);
572
573 intr = wl->fw_status->intr;
574 intr &= WLCORE_ALL_INTR_MASK;
575 if (!intr) {
576 done = true;
577 continue;
578 }
579
580 if (unlikely(intr & WL1271_ACX_INTR_WATCHDOG)) {
581 wl1271_error("HW watchdog interrupt received! starting recovery.");
582 wl->watchdog_recovery = true;
583 ret = -EIO;
584
585 /* restarting the chip. ignore any other interrupt. */
586 goto out;
587 }
588
589 if (unlikely(intr & WL1271_ACX_SW_INTR_WATCHDOG)) {
590 wl1271_error("SW watchdog interrupt received! "
591 "starting recovery.");
592 wl->watchdog_recovery = true;
593 ret = -EIO;
594
595 /* restarting the chip. ignore any other interrupt. */
596 goto out;
597 }
598
599 if (likely(intr & WL1271_ACX_INTR_DATA)) {
600 wl1271_debug(DEBUG_IRQ, "WL1271_ACX_INTR_DATA");
601
602 ret = wlcore_rx(wl, wl->fw_status);
603 if (ret < 0)
604 goto out;
605
606 /* Check if any tx blocks were freed */
607 spin_lock_irqsave(&wl->wl_lock, flags);
608 if (!test_bit(WL1271_FLAG_FW_TX_BUSY, &wl->flags) &&
609 wl1271_tx_total_queue_count(wl) > 0) {
610 spin_unlock_irqrestore(&wl->wl_lock, flags);
611 /*
612 * In order to avoid starvation of the TX path,
613 * call the work function directly.
614 */
615 ret = wlcore_tx_work_locked(wl);
616 if (ret < 0)
617 goto out;
618 } else {
619 spin_unlock_irqrestore(&wl->wl_lock, flags);
620 }
621
622 /* check for tx results */
623 ret = wlcore_hw_tx_delayed_compl(wl);
624 if (ret < 0)
625 goto out;
626
627 /* Make sure the deferred queues don't get too long */
628 defer_count = skb_queue_len(&wl->deferred_tx_queue) +
629 skb_queue_len(&wl->deferred_rx_queue);
630 if (defer_count > WL1271_DEFERRED_QUEUE_LIMIT)
631 wl1271_flush_deferred_work(wl);
632 }
633
634 if (intr & WL1271_ACX_INTR_EVENT_A) {
635 wl1271_debug(DEBUG_IRQ, "WL1271_ACX_INTR_EVENT_A");
636 ret = wl1271_event_handle(wl, 0);
637 if (ret < 0)
638 goto out;
639 }
640
641 if (intr & WL1271_ACX_INTR_EVENT_B) {
642 wl1271_debug(DEBUG_IRQ, "WL1271_ACX_INTR_EVENT_B");
643 ret = wl1271_event_handle(wl, 1);
644 if (ret < 0)
645 goto out;
646 }
647
648 if (intr & WL1271_ACX_INTR_INIT_COMPLETE)
649 wl1271_debug(DEBUG_IRQ,
650 "WL1271_ACX_INTR_INIT_COMPLETE");
651
652 if (intr & WL1271_ACX_INTR_HW_AVAILABLE)
653 wl1271_debug(DEBUG_IRQ, "WL1271_ACX_INTR_HW_AVAILABLE");
654 }
655
656 pm_runtime_mark_last_busy(wl->dev);
657 pm_runtime_put_autosuspend(wl->dev);
658
659 out:
660 return ret;
661 }
662
wlcore_irq(int irq,void * cookie)663 static irqreturn_t wlcore_irq(int irq, void *cookie)
664 {
665 int ret;
666 unsigned long flags;
667 struct wl1271 *wl = cookie;
668
669 /* complete the ELP completion */
670 spin_lock_irqsave(&wl->wl_lock, flags);
671 set_bit(WL1271_FLAG_IRQ_RUNNING, &wl->flags);
672 if (wl->elp_compl) {
673 complete(wl->elp_compl);
674 wl->elp_compl = NULL;
675 }
676
677 if (test_bit(WL1271_FLAG_SUSPENDED, &wl->flags)) {
678 /* don't enqueue a work right now. mark it as pending */
679 set_bit(WL1271_FLAG_PENDING_WORK, &wl->flags);
680 wl1271_debug(DEBUG_IRQ, "should not enqueue work");
681 disable_irq_nosync(wl->irq);
682 pm_wakeup_event(wl->dev, 0);
683 spin_unlock_irqrestore(&wl->wl_lock, flags);
684 return IRQ_HANDLED;
685 }
686 spin_unlock_irqrestore(&wl->wl_lock, flags);
687
688 /* TX might be handled here, avoid redundant work */
689 set_bit(WL1271_FLAG_TX_PENDING, &wl->flags);
690 cancel_work_sync(&wl->tx_work);
691
692 mutex_lock(&wl->mutex);
693
694 ret = wlcore_irq_locked(wl);
695 if (ret)
696 wl12xx_queue_recovery_work(wl);
697
698 spin_lock_irqsave(&wl->wl_lock, flags);
699 /* In case TX was not handled here, queue TX work */
700 clear_bit(WL1271_FLAG_TX_PENDING, &wl->flags);
701 if (!test_bit(WL1271_FLAG_FW_TX_BUSY, &wl->flags) &&
702 wl1271_tx_total_queue_count(wl) > 0)
703 ieee80211_queue_work(wl->hw, &wl->tx_work);
704 spin_unlock_irqrestore(&wl->wl_lock, flags);
705
706 mutex_unlock(&wl->mutex);
707
708 return IRQ_HANDLED;
709 }
710
711 struct vif_counter_data {
712 u8 counter;
713
714 struct ieee80211_vif *cur_vif;
715 bool cur_vif_running;
716 };
717
wl12xx_vif_count_iter(void * data,u8 * mac,struct ieee80211_vif * vif)718 static void wl12xx_vif_count_iter(void *data, u8 *mac,
719 struct ieee80211_vif *vif)
720 {
721 struct vif_counter_data *counter = data;
722
723 counter->counter++;
724 if (counter->cur_vif == vif)
725 counter->cur_vif_running = true;
726 }
727
728 /* caller must not hold wl->mutex, as it might deadlock */
wl12xx_get_vif_count(struct ieee80211_hw * hw,struct ieee80211_vif * cur_vif,struct vif_counter_data * data)729 static void wl12xx_get_vif_count(struct ieee80211_hw *hw,
730 struct ieee80211_vif *cur_vif,
731 struct vif_counter_data *data)
732 {
733 memset(data, 0, sizeof(*data));
734 data->cur_vif = cur_vif;
735
736 ieee80211_iterate_active_interfaces(hw, IEEE80211_IFACE_ITER_RESUME_ALL,
737 wl12xx_vif_count_iter, data);
738 }
739
wl12xx_fetch_firmware(struct wl1271 * wl,bool plt)740 static int wl12xx_fetch_firmware(struct wl1271 *wl, bool plt)
741 {
742 const struct firmware *fw;
743 const char *fw_name;
744 enum wl12xx_fw_type fw_type;
745 int ret;
746
747 if (plt) {
748 fw_type = WL12XX_FW_TYPE_PLT;
749 fw_name = wl->plt_fw_name;
750 } else {
751 /*
752 * we can't call wl12xx_get_vif_count() here because
753 * wl->mutex is taken, so use the cached last_vif_count value
754 */
755 if (wl->last_vif_count > 1 && wl->mr_fw_name) {
756 fw_type = WL12XX_FW_TYPE_MULTI;
757 fw_name = wl->mr_fw_name;
758 } else {
759 fw_type = WL12XX_FW_TYPE_NORMAL;
760 fw_name = wl->sr_fw_name;
761 }
762 }
763
764 if (wl->fw_type == fw_type)
765 return 0;
766
767 wl1271_debug(DEBUG_BOOT, "booting firmware %s", fw_name);
768
769 ret = request_firmware(&fw, fw_name, wl->dev);
770
771 if (ret < 0) {
772 wl1271_error("could not get firmware %s: %d", fw_name, ret);
773 return ret;
774 }
775
776 if (fw->size % 4) {
777 wl1271_error("firmware size is not multiple of 32 bits: %zu",
778 fw->size);
779 ret = -EILSEQ;
780 goto out;
781 }
782
783 vfree(wl->fw);
784 wl->fw_type = WL12XX_FW_TYPE_NONE;
785 wl->fw_len = fw->size;
786 wl->fw = vmalloc(wl->fw_len);
787
788 if (!wl->fw) {
789 wl1271_error("could not allocate memory for the firmware");
790 ret = -ENOMEM;
791 goto out;
792 }
793
794 memcpy(wl->fw, fw->data, wl->fw_len);
795 ret = 0;
796 wl->fw_type = fw_type;
797 out:
798 release_firmware(fw);
799
800 return ret;
801 }
802
wl12xx_queue_recovery_work(struct wl1271 * wl)803 void wl12xx_queue_recovery_work(struct wl1271 *wl)
804 {
805 /* Avoid a recursive recovery */
806 if (wl->state == WLCORE_STATE_ON) {
807 WARN_ON(!test_bit(WL1271_FLAG_INTENDED_FW_RECOVERY,
808 &wl->flags));
809
810 wl->state = WLCORE_STATE_RESTARTING;
811 set_bit(WL1271_FLAG_RECOVERY_IN_PROGRESS, &wl->flags);
812 ieee80211_queue_work(wl->hw, &wl->recovery_work);
813 }
814 }
815
wl12xx_copy_fwlog(struct wl1271 * wl,u8 * memblock,size_t maxlen)816 size_t wl12xx_copy_fwlog(struct wl1271 *wl, u8 *memblock, size_t maxlen)
817 {
818 size_t len;
819
820 /* Make sure we have enough room */
821 len = min_t(size_t, maxlen, PAGE_SIZE - wl->fwlog_size);
822
823 /* Fill the FW log file, consumed by the sysfs fwlog entry */
824 memcpy(wl->fwlog + wl->fwlog_size, memblock, len);
825 wl->fwlog_size += len;
826
827 return len;
828 }
829
wl12xx_read_fwlog_panic(struct wl1271 * wl)830 static void wl12xx_read_fwlog_panic(struct wl1271 *wl)
831 {
832 u32 end_of_log = 0;
833 int error;
834
835 if (wl->quirks & WLCORE_QUIRK_FWLOG_NOT_IMPLEMENTED)
836 return;
837
838 wl1271_info("Reading FW panic log");
839
840 /*
841 * Make sure the chip is awake and the logger isn't active.
842 * Do not send a stop fwlog command if the fw is hanged or if
843 * dbgpins are used (due to some fw bug).
844 */
845 error = pm_runtime_get_sync(wl->dev);
846 if (error < 0) {
847 pm_runtime_put_noidle(wl->dev);
848 return;
849 }
850 if (!wl->watchdog_recovery &&
851 wl->conf.fwlog.output != WL12XX_FWLOG_OUTPUT_DBG_PINS)
852 wl12xx_cmd_stop_fwlog(wl);
853
854 /* Traverse the memory blocks linked list */
855 do {
856 end_of_log = wlcore_event_fw_logger(wl);
857 if (end_of_log == 0) {
858 msleep(100);
859 end_of_log = wlcore_event_fw_logger(wl);
860 }
861 } while (end_of_log != 0);
862 }
863
wlcore_save_freed_pkts(struct wl1271 * wl,struct wl12xx_vif * wlvif,u8 hlid,struct ieee80211_sta * sta)864 static void wlcore_save_freed_pkts(struct wl1271 *wl, struct wl12xx_vif *wlvif,
865 u8 hlid, struct ieee80211_sta *sta)
866 {
867 struct wl1271_station *wl_sta;
868 u32 sqn_recovery_padding = WL1271_TX_SQN_POST_RECOVERY_PADDING;
869
870 wl_sta = (void *)sta->drv_priv;
871 wl_sta->total_freed_pkts = wl->links[hlid].total_freed_pkts;
872
873 /*
874 * increment the initial seq number on recovery to account for
875 * transmitted packets that we haven't yet got in the FW status
876 */
877 if (wlvif->encryption_type == KEY_GEM)
878 sqn_recovery_padding = WL1271_TX_SQN_POST_RECOVERY_PADDING_GEM;
879
880 if (test_bit(WL1271_FLAG_RECOVERY_IN_PROGRESS, &wl->flags))
881 wl_sta->total_freed_pkts += sqn_recovery_padding;
882 }
883
wlcore_save_freed_pkts_addr(struct wl1271 * wl,struct wl12xx_vif * wlvif,u8 hlid,const u8 * addr)884 static void wlcore_save_freed_pkts_addr(struct wl1271 *wl,
885 struct wl12xx_vif *wlvif,
886 u8 hlid, const u8 *addr)
887 {
888 struct ieee80211_sta *sta;
889 struct ieee80211_vif *vif = wl12xx_wlvif_to_vif(wlvif);
890
891 if (WARN_ON(hlid == WL12XX_INVALID_LINK_ID ||
892 is_zero_ether_addr(addr)))
893 return;
894
895 rcu_read_lock();
896 sta = ieee80211_find_sta(vif, addr);
897 if (sta)
898 wlcore_save_freed_pkts(wl, wlvif, hlid, sta);
899 rcu_read_unlock();
900 }
901
wlcore_print_recovery(struct wl1271 * wl)902 static void wlcore_print_recovery(struct wl1271 *wl)
903 {
904 u32 pc = 0;
905 u32 hint_sts = 0;
906 int ret;
907
908 wl1271_info("Hardware recovery in progress. FW ver: %s",
909 wl->chip.fw_ver_str);
910
911 /* change partitions momentarily so we can read the FW pc */
912 ret = wlcore_set_partition(wl, &wl->ptable[PART_BOOT]);
913 if (ret < 0)
914 return;
915
916 ret = wlcore_read_reg(wl, REG_PC_ON_RECOVERY, &pc);
917 if (ret < 0)
918 return;
919
920 ret = wlcore_read_reg(wl, REG_INTERRUPT_NO_CLEAR, &hint_sts);
921 if (ret < 0)
922 return;
923
924 wl1271_info("pc: 0x%x, hint_sts: 0x%08x count: %d",
925 pc, hint_sts, ++wl->recovery_count);
926
927 wlcore_set_partition(wl, &wl->ptable[PART_WORK]);
928 }
929
930
wl1271_recovery_work(struct work_struct * work)931 static void wl1271_recovery_work(struct work_struct *work)
932 {
933 struct wl1271 *wl =
934 container_of(work, struct wl1271, recovery_work);
935 struct wl12xx_vif *wlvif;
936 struct ieee80211_vif *vif;
937 int error;
938
939 mutex_lock(&wl->mutex);
940
941 if (wl->state == WLCORE_STATE_OFF || wl->plt)
942 goto out_unlock;
943
944 error = pm_runtime_get_sync(wl->dev);
945 if (error < 0) {
946 wl1271_warning("Enable for recovery failed");
947 pm_runtime_put_noidle(wl->dev);
948 }
949 wlcore_disable_interrupts_nosync(wl);
950
951 if (!test_bit(WL1271_FLAG_INTENDED_FW_RECOVERY, &wl->flags)) {
952 if (wl->conf.fwlog.output == WL12XX_FWLOG_OUTPUT_HOST)
953 wl12xx_read_fwlog_panic(wl);
954 wlcore_print_recovery(wl);
955 }
956
957 BUG_ON(wl->conf.recovery.bug_on_recovery &&
958 !test_bit(WL1271_FLAG_INTENDED_FW_RECOVERY, &wl->flags));
959
960 if (wl->conf.recovery.no_recovery) {
961 wl1271_info("No recovery (chosen on module load). Fw will remain stuck.");
962 goto out_unlock;
963 }
964
965 /* Prevent spurious TX during FW restart */
966 wlcore_stop_queues(wl, WLCORE_QUEUE_STOP_REASON_FW_RESTART);
967
968 /* reboot the chipset */
969 while (!list_empty(&wl->wlvif_list)) {
970 wlvif = list_first_entry(&wl->wlvif_list,
971 struct wl12xx_vif, list);
972 vif = wl12xx_wlvif_to_vif(wlvif);
973
974 if (wlvif->bss_type == BSS_TYPE_STA_BSS &&
975 test_bit(WLVIF_FLAG_STA_ASSOCIATED, &wlvif->flags)) {
976 wlcore_save_freed_pkts_addr(wl, wlvif, wlvif->sta.hlid,
977 vif->bss_conf.bssid);
978 }
979
980 __wl1271_op_remove_interface(wl, vif, false);
981 }
982
983 wlcore_op_stop_locked(wl);
984 pm_runtime_mark_last_busy(wl->dev);
985 pm_runtime_put_autosuspend(wl->dev);
986
987 ieee80211_restart_hw(wl->hw);
988
989 /*
990 * Its safe to enable TX now - the queues are stopped after a request
991 * to restart the HW.
992 */
993 wlcore_wake_queues(wl, WLCORE_QUEUE_STOP_REASON_FW_RESTART);
994
995 out_unlock:
996 wl->watchdog_recovery = false;
997 clear_bit(WL1271_FLAG_RECOVERY_IN_PROGRESS, &wl->flags);
998 mutex_unlock(&wl->mutex);
999 }
1000
wlcore_fw_wakeup(struct wl1271 * wl)1001 static int wlcore_fw_wakeup(struct wl1271 *wl)
1002 {
1003 return wlcore_raw_write32(wl, HW_ACCESS_ELP_CTRL_REG, ELPCTRL_WAKE_UP);
1004 }
1005
wl1271_setup(struct wl1271 * wl)1006 static int wl1271_setup(struct wl1271 *wl)
1007 {
1008 wl->raw_fw_status = kzalloc(wl->fw_status_len, GFP_KERNEL);
1009 if (!wl->raw_fw_status)
1010 goto err;
1011
1012 wl->fw_status = kzalloc(sizeof(*wl->fw_status), GFP_KERNEL);
1013 if (!wl->fw_status)
1014 goto err;
1015
1016 wl->tx_res_if = kzalloc(sizeof(*wl->tx_res_if), GFP_KERNEL);
1017 if (!wl->tx_res_if)
1018 goto err;
1019
1020 return 0;
1021 err:
1022 kfree(wl->fw_status);
1023 kfree(wl->raw_fw_status);
1024 return -ENOMEM;
1025 }
1026
wl12xx_set_power_on(struct wl1271 * wl)1027 static int wl12xx_set_power_on(struct wl1271 *wl)
1028 {
1029 int ret;
1030
1031 msleep(WL1271_PRE_POWER_ON_SLEEP);
1032 ret = wl1271_power_on(wl);
1033 if (ret < 0)
1034 goto out;
1035 msleep(WL1271_POWER_ON_SLEEP);
1036 wl1271_io_reset(wl);
1037 wl1271_io_init(wl);
1038
1039 ret = wlcore_set_partition(wl, &wl->ptable[PART_BOOT]);
1040 if (ret < 0)
1041 goto fail;
1042
1043 /* ELP module wake up */
1044 ret = wlcore_fw_wakeup(wl);
1045 if (ret < 0)
1046 goto fail;
1047
1048 out:
1049 return ret;
1050
1051 fail:
1052 wl1271_power_off(wl);
1053 return ret;
1054 }
1055
wl12xx_chip_wakeup(struct wl1271 * wl,bool plt)1056 static int wl12xx_chip_wakeup(struct wl1271 *wl, bool plt)
1057 {
1058 int ret = 0;
1059
1060 ret = wl12xx_set_power_on(wl);
1061 if (ret < 0)
1062 goto out;
1063
1064 /*
1065 * For wl127x based devices we could use the default block
1066 * size (512 bytes), but due to a bug in the sdio driver, we
1067 * need to set it explicitly after the chip is powered on. To
1068 * simplify the code and since the performance impact is
1069 * negligible, we use the same block size for all different
1070 * chip types.
1071 *
1072 * Check if the bus supports blocksize alignment and, if it
1073 * doesn't, make sure we don't have the quirk.
1074 */
1075 if (!wl1271_set_block_size(wl))
1076 wl->quirks &= ~WLCORE_QUIRK_TX_BLOCKSIZE_ALIGN;
1077
1078 /* TODO: make sure the lower driver has set things up correctly */
1079
1080 ret = wl1271_setup(wl);
1081 if (ret < 0)
1082 goto out;
1083
1084 ret = wl12xx_fetch_firmware(wl, plt);
1085 if (ret < 0)
1086 goto out;
1087
1088 out:
1089 return ret;
1090 }
1091
wl1271_plt_start(struct wl1271 * wl,const enum plt_mode plt_mode)1092 int wl1271_plt_start(struct wl1271 *wl, const enum plt_mode plt_mode)
1093 {
1094 int retries = WL1271_BOOT_RETRIES;
1095 struct wiphy *wiphy = wl->hw->wiphy;
1096
1097 static const char* const PLT_MODE[] = {
1098 "PLT_OFF",
1099 "PLT_ON",
1100 "PLT_FEM_DETECT",
1101 "PLT_CHIP_AWAKE"
1102 };
1103
1104 int ret;
1105
1106 mutex_lock(&wl->mutex);
1107
1108 wl1271_notice("power up");
1109
1110 if (wl->state != WLCORE_STATE_OFF) {
1111 wl1271_error("cannot go into PLT state because not "
1112 "in off state: %d", wl->state);
1113 ret = -EBUSY;
1114 goto out;
1115 }
1116
1117 /* Indicate to lower levels that we are now in PLT mode */
1118 wl->plt = true;
1119 wl->plt_mode = plt_mode;
1120
1121 while (retries) {
1122 retries--;
1123 ret = wl12xx_chip_wakeup(wl, true);
1124 if (ret < 0)
1125 goto power_off;
1126
1127 if (plt_mode != PLT_CHIP_AWAKE) {
1128 ret = wl->ops->plt_init(wl);
1129 if (ret < 0)
1130 goto power_off;
1131 }
1132
1133 wl->state = WLCORE_STATE_ON;
1134 wl1271_notice("firmware booted in PLT mode %s (%s)",
1135 PLT_MODE[plt_mode],
1136 wl->chip.fw_ver_str);
1137
1138 /* update hw/fw version info in wiphy struct */
1139 wiphy->hw_version = wl->chip.id;
1140 strncpy(wiphy->fw_version, wl->chip.fw_ver_str,
1141 sizeof(wiphy->fw_version));
1142
1143 goto out;
1144
1145 power_off:
1146 wl1271_power_off(wl);
1147 }
1148
1149 wl->plt = false;
1150 wl->plt_mode = PLT_OFF;
1151
1152 wl1271_error("firmware boot in PLT mode failed despite %d retries",
1153 WL1271_BOOT_RETRIES);
1154 out:
1155 mutex_unlock(&wl->mutex);
1156
1157 return ret;
1158 }
1159
wl1271_plt_stop(struct wl1271 * wl)1160 int wl1271_plt_stop(struct wl1271 *wl)
1161 {
1162 int ret = 0;
1163
1164 wl1271_notice("power down");
1165
1166 /*
1167 * Interrupts must be disabled before setting the state to OFF.
1168 * Otherwise, the interrupt handler might be called and exit without
1169 * reading the interrupt status.
1170 */
1171 wlcore_disable_interrupts(wl);
1172 mutex_lock(&wl->mutex);
1173 if (!wl->plt) {
1174 mutex_unlock(&wl->mutex);
1175
1176 /*
1177 * This will not necessarily enable interrupts as interrupts
1178 * may have been disabled when op_stop was called. It will,
1179 * however, balance the above call to disable_interrupts().
1180 */
1181 wlcore_enable_interrupts(wl);
1182
1183 wl1271_error("cannot power down because not in PLT "
1184 "state: %d", wl->state);
1185 ret = -EBUSY;
1186 goto out;
1187 }
1188
1189 mutex_unlock(&wl->mutex);
1190
1191 wl1271_flush_deferred_work(wl);
1192 cancel_work_sync(&wl->netstack_work);
1193 cancel_work_sync(&wl->recovery_work);
1194 cancel_delayed_work_sync(&wl->tx_watchdog_work);
1195
1196 mutex_lock(&wl->mutex);
1197 wl1271_power_off(wl);
1198 wl->flags = 0;
1199 wl->sleep_auth = WL1271_PSM_ILLEGAL;
1200 wl->state = WLCORE_STATE_OFF;
1201 wl->plt = false;
1202 wl->plt_mode = PLT_OFF;
1203 wl->rx_counter = 0;
1204 mutex_unlock(&wl->mutex);
1205
1206 out:
1207 return ret;
1208 }
1209
wl1271_op_tx(struct ieee80211_hw * hw,struct ieee80211_tx_control * control,struct sk_buff * skb)1210 static void wl1271_op_tx(struct ieee80211_hw *hw,
1211 struct ieee80211_tx_control *control,
1212 struct sk_buff *skb)
1213 {
1214 struct wl1271 *wl = hw->priv;
1215 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
1216 struct ieee80211_vif *vif = info->control.vif;
1217 struct wl12xx_vif *wlvif = NULL;
1218 unsigned long flags;
1219 int q, mapping;
1220 u8 hlid;
1221
1222 if (!vif) {
1223 wl1271_debug(DEBUG_TX, "DROP skb with no vif");
1224 ieee80211_free_txskb(hw, skb);
1225 return;
1226 }
1227
1228 wlvif = wl12xx_vif_to_data(vif);
1229 mapping = skb_get_queue_mapping(skb);
1230 q = wl1271_tx_get_queue(mapping);
1231
1232 hlid = wl12xx_tx_get_hlid(wl, wlvif, skb, control->sta);
1233
1234 spin_lock_irqsave(&wl->wl_lock, flags);
1235
1236 /*
1237 * drop the packet if the link is invalid or the queue is stopped
1238 * for any reason but watermark. Watermark is a "soft"-stop so we
1239 * allow these packets through.
1240 */
1241 if (hlid == WL12XX_INVALID_LINK_ID ||
1242 (!test_bit(hlid, wlvif->links_map)) ||
1243 (wlcore_is_queue_stopped_locked(wl, wlvif, q) &&
1244 !wlcore_is_queue_stopped_by_reason_locked(wl, wlvif, q,
1245 WLCORE_QUEUE_STOP_REASON_WATERMARK))) {
1246 wl1271_debug(DEBUG_TX, "DROP skb hlid %d q %d", hlid, q);
1247 ieee80211_free_txskb(hw, skb);
1248 goto out;
1249 }
1250
1251 wl1271_debug(DEBUG_TX, "queue skb hlid %d q %d len %d",
1252 hlid, q, skb->len);
1253 skb_queue_tail(&wl->links[hlid].tx_queue[q], skb);
1254
1255 wl->tx_queue_count[q]++;
1256 wlvif->tx_queue_count[q]++;
1257
1258 /*
1259 * The workqueue is slow to process the tx_queue and we need stop
1260 * the queue here, otherwise the queue will get too long.
1261 */
1262 if (wlvif->tx_queue_count[q] >= WL1271_TX_QUEUE_HIGH_WATERMARK &&
1263 !wlcore_is_queue_stopped_by_reason_locked(wl, wlvif, q,
1264 WLCORE_QUEUE_STOP_REASON_WATERMARK)) {
1265 wl1271_debug(DEBUG_TX, "op_tx: stopping queues for q %d", q);
1266 wlcore_stop_queue_locked(wl, wlvif, q,
1267 WLCORE_QUEUE_STOP_REASON_WATERMARK);
1268 }
1269
1270 /*
1271 * The chip specific setup must run before the first TX packet -
1272 * before that, the tx_work will not be initialized!
1273 */
1274
1275 if (!test_bit(WL1271_FLAG_FW_TX_BUSY, &wl->flags) &&
1276 !test_bit(WL1271_FLAG_TX_PENDING, &wl->flags))
1277 ieee80211_queue_work(wl->hw, &wl->tx_work);
1278
1279 out:
1280 spin_unlock_irqrestore(&wl->wl_lock, flags);
1281 }
1282
wl1271_tx_dummy_packet(struct wl1271 * wl)1283 int wl1271_tx_dummy_packet(struct wl1271 *wl)
1284 {
1285 unsigned long flags;
1286 int q;
1287
1288 /* no need to queue a new dummy packet if one is already pending */
1289 if (test_bit(WL1271_FLAG_DUMMY_PACKET_PENDING, &wl->flags))
1290 return 0;
1291
1292 q = wl1271_tx_get_queue(skb_get_queue_mapping(wl->dummy_packet));
1293
1294 spin_lock_irqsave(&wl->wl_lock, flags);
1295 set_bit(WL1271_FLAG_DUMMY_PACKET_PENDING, &wl->flags);
1296 wl->tx_queue_count[q]++;
1297 spin_unlock_irqrestore(&wl->wl_lock, flags);
1298
1299 /* The FW is low on RX memory blocks, so send the dummy packet asap */
1300 if (!test_bit(WL1271_FLAG_FW_TX_BUSY, &wl->flags))
1301 return wlcore_tx_work_locked(wl);
1302
1303 /*
1304 * If the FW TX is busy, TX work will be scheduled by the threaded
1305 * interrupt handler function
1306 */
1307 return 0;
1308 }
1309
1310 /*
1311 * The size of the dummy packet should be at least 1400 bytes. However, in
1312 * order to minimize the number of bus transactions, aligning it to 512 bytes
1313 * boundaries could be beneficial, performance wise
1314 */
1315 #define TOTAL_TX_DUMMY_PACKET_SIZE (ALIGN(1400, 512))
1316
wl12xx_alloc_dummy_packet(struct wl1271 * wl)1317 static struct sk_buff *wl12xx_alloc_dummy_packet(struct wl1271 *wl)
1318 {
1319 struct sk_buff *skb;
1320 struct ieee80211_hdr_3addr *hdr;
1321 unsigned int dummy_packet_size;
1322
1323 dummy_packet_size = TOTAL_TX_DUMMY_PACKET_SIZE -
1324 sizeof(struct wl1271_tx_hw_descr) - sizeof(*hdr);
1325
1326 skb = dev_alloc_skb(TOTAL_TX_DUMMY_PACKET_SIZE);
1327 if (!skb) {
1328 wl1271_warning("Failed to allocate a dummy packet skb");
1329 return NULL;
1330 }
1331
1332 skb_reserve(skb, sizeof(struct wl1271_tx_hw_descr));
1333
1334 hdr = skb_put_zero(skb, sizeof(*hdr));
1335 hdr->frame_control = cpu_to_le16(IEEE80211_FTYPE_DATA |
1336 IEEE80211_STYPE_NULLFUNC |
1337 IEEE80211_FCTL_TODS);
1338
1339 skb_put_zero(skb, dummy_packet_size);
1340
1341 /* Dummy packets require the TID to be management */
1342 skb->priority = WL1271_TID_MGMT;
1343
1344 /* Initialize all fields that might be used */
1345 skb_set_queue_mapping(skb, 0);
1346 memset(IEEE80211_SKB_CB(skb), 0, sizeof(struct ieee80211_tx_info));
1347
1348 return skb;
1349 }
1350
1351
1352 static int
wl1271_validate_wowlan_pattern(struct cfg80211_pkt_pattern * p)1353 wl1271_validate_wowlan_pattern(struct cfg80211_pkt_pattern *p)
1354 {
1355 int num_fields = 0, in_field = 0, fields_size = 0;
1356 int i, pattern_len = 0;
1357
1358 if (!p->mask) {
1359 wl1271_warning("No mask in WoWLAN pattern");
1360 return -EINVAL;
1361 }
1362
1363 /*
1364 * The pattern is broken up into segments of bytes at different offsets
1365 * that need to be checked by the FW filter. Each segment is called
1366 * a field in the FW API. We verify that the total number of fields
1367 * required for this pattern won't exceed FW limits (8)
1368 * as well as the total fields buffer won't exceed the FW limit.
1369 * Note that if there's a pattern which crosses Ethernet/IP header
1370 * boundary a new field is required.
1371 */
1372 for (i = 0; i < p->pattern_len; i++) {
1373 if (test_bit(i, (unsigned long *)p->mask)) {
1374 if (!in_field) {
1375 in_field = 1;
1376 pattern_len = 1;
1377 } else {
1378 if (i == WL1271_RX_FILTER_ETH_HEADER_SIZE) {
1379 num_fields++;
1380 fields_size += pattern_len +
1381 RX_FILTER_FIELD_OVERHEAD;
1382 pattern_len = 1;
1383 } else
1384 pattern_len++;
1385 }
1386 } else {
1387 if (in_field) {
1388 in_field = 0;
1389 fields_size += pattern_len +
1390 RX_FILTER_FIELD_OVERHEAD;
1391 num_fields++;
1392 }
1393 }
1394 }
1395
1396 if (in_field) {
1397 fields_size += pattern_len + RX_FILTER_FIELD_OVERHEAD;
1398 num_fields++;
1399 }
1400
1401 if (num_fields > WL1271_RX_FILTER_MAX_FIELDS) {
1402 wl1271_warning("RX Filter too complex. Too many segments");
1403 return -EINVAL;
1404 }
1405
1406 if (fields_size > WL1271_RX_FILTER_MAX_FIELDS_SIZE) {
1407 wl1271_warning("RX filter pattern is too big");
1408 return -E2BIG;
1409 }
1410
1411 return 0;
1412 }
1413
wl1271_rx_filter_alloc(void)1414 struct wl12xx_rx_filter *wl1271_rx_filter_alloc(void)
1415 {
1416 return kzalloc(sizeof(struct wl12xx_rx_filter), GFP_KERNEL);
1417 }
1418
wl1271_rx_filter_free(struct wl12xx_rx_filter * filter)1419 void wl1271_rx_filter_free(struct wl12xx_rx_filter *filter)
1420 {
1421 int i;
1422
1423 if (filter == NULL)
1424 return;
1425
1426 for (i = 0; i < filter->num_fields; i++)
1427 kfree(filter->fields[i].pattern);
1428
1429 kfree(filter);
1430 }
1431
wl1271_rx_filter_alloc_field(struct wl12xx_rx_filter * filter,u16 offset,u8 flags,const u8 * pattern,u8 len)1432 int wl1271_rx_filter_alloc_field(struct wl12xx_rx_filter *filter,
1433 u16 offset, u8 flags,
1434 const u8 *pattern, u8 len)
1435 {
1436 struct wl12xx_rx_filter_field *field;
1437
1438 if (filter->num_fields == WL1271_RX_FILTER_MAX_FIELDS) {
1439 wl1271_warning("Max fields per RX filter. can't alloc another");
1440 return -EINVAL;
1441 }
1442
1443 field = &filter->fields[filter->num_fields];
1444
1445 field->pattern = kzalloc(len, GFP_KERNEL);
1446 if (!field->pattern) {
1447 wl1271_warning("Failed to allocate RX filter pattern");
1448 return -ENOMEM;
1449 }
1450
1451 filter->num_fields++;
1452
1453 field->offset = cpu_to_le16(offset);
1454 field->flags = flags;
1455 field->len = len;
1456 memcpy(field->pattern, pattern, len);
1457
1458 return 0;
1459 }
1460
wl1271_rx_filter_get_fields_size(struct wl12xx_rx_filter * filter)1461 int wl1271_rx_filter_get_fields_size(struct wl12xx_rx_filter *filter)
1462 {
1463 int i, fields_size = 0;
1464
1465 for (i = 0; i < filter->num_fields; i++)
1466 fields_size += filter->fields[i].len +
1467 sizeof(struct wl12xx_rx_filter_field) -
1468 sizeof(u8 *);
1469
1470 return fields_size;
1471 }
1472
wl1271_rx_filter_flatten_fields(struct wl12xx_rx_filter * filter,u8 * buf)1473 void wl1271_rx_filter_flatten_fields(struct wl12xx_rx_filter *filter,
1474 u8 *buf)
1475 {
1476 int i;
1477 struct wl12xx_rx_filter_field *field;
1478
1479 for (i = 0; i < filter->num_fields; i++) {
1480 field = (struct wl12xx_rx_filter_field *)buf;
1481
1482 field->offset = filter->fields[i].offset;
1483 field->flags = filter->fields[i].flags;
1484 field->len = filter->fields[i].len;
1485
1486 memcpy(&field->pattern, filter->fields[i].pattern, field->len);
1487 buf += sizeof(struct wl12xx_rx_filter_field) -
1488 sizeof(u8 *) + field->len;
1489 }
1490 }
1491
1492 /*
1493 * Allocates an RX filter returned through f
1494 * which needs to be freed using rx_filter_free()
1495 */
1496 static int
wl1271_convert_wowlan_pattern_to_rx_filter(struct cfg80211_pkt_pattern * p,struct wl12xx_rx_filter ** f)1497 wl1271_convert_wowlan_pattern_to_rx_filter(struct cfg80211_pkt_pattern *p,
1498 struct wl12xx_rx_filter **f)
1499 {
1500 int i, j, ret = 0;
1501 struct wl12xx_rx_filter *filter;
1502 u16 offset;
1503 u8 flags, len;
1504
1505 filter = wl1271_rx_filter_alloc();
1506 if (!filter) {
1507 wl1271_warning("Failed to alloc rx filter");
1508 ret = -ENOMEM;
1509 goto err;
1510 }
1511
1512 i = 0;
1513 while (i < p->pattern_len) {
1514 if (!test_bit(i, (unsigned long *)p->mask)) {
1515 i++;
1516 continue;
1517 }
1518
1519 for (j = i; j < p->pattern_len; j++) {
1520 if (!test_bit(j, (unsigned long *)p->mask))
1521 break;
1522
1523 if (i < WL1271_RX_FILTER_ETH_HEADER_SIZE &&
1524 j >= WL1271_RX_FILTER_ETH_HEADER_SIZE)
1525 break;
1526 }
1527
1528 if (i < WL1271_RX_FILTER_ETH_HEADER_SIZE) {
1529 offset = i;
1530 flags = WL1271_RX_FILTER_FLAG_ETHERNET_HEADER;
1531 } else {
1532 offset = i - WL1271_RX_FILTER_ETH_HEADER_SIZE;
1533 flags = WL1271_RX_FILTER_FLAG_IP_HEADER;
1534 }
1535
1536 len = j - i;
1537
1538 ret = wl1271_rx_filter_alloc_field(filter,
1539 offset,
1540 flags,
1541 &p->pattern[i], len);
1542 if (ret)
1543 goto err;
1544
1545 i = j;
1546 }
1547
1548 filter->action = FILTER_SIGNAL;
1549
1550 *f = filter;
1551 return 0;
1552
1553 err:
1554 wl1271_rx_filter_free(filter);
1555 *f = NULL;
1556
1557 return ret;
1558 }
1559
wl1271_configure_wowlan(struct wl1271 * wl,struct cfg80211_wowlan * wow)1560 static int wl1271_configure_wowlan(struct wl1271 *wl,
1561 struct cfg80211_wowlan *wow)
1562 {
1563 int i, ret;
1564
1565 if (!wow || wow->any || !wow->n_patterns) {
1566 ret = wl1271_acx_default_rx_filter_enable(wl, 0,
1567 FILTER_SIGNAL);
1568 if (ret)
1569 goto out;
1570
1571 ret = wl1271_rx_filter_clear_all(wl);
1572 if (ret)
1573 goto out;
1574
1575 return 0;
1576 }
1577
1578 if (WARN_ON(wow->n_patterns > WL1271_MAX_RX_FILTERS))
1579 return -EINVAL;
1580
1581 /* Validate all incoming patterns before clearing current FW state */
1582 for (i = 0; i < wow->n_patterns; i++) {
1583 ret = wl1271_validate_wowlan_pattern(&wow->patterns[i]);
1584 if (ret) {
1585 wl1271_warning("Bad wowlan pattern %d", i);
1586 return ret;
1587 }
1588 }
1589
1590 ret = wl1271_acx_default_rx_filter_enable(wl, 0, FILTER_SIGNAL);
1591 if (ret)
1592 goto out;
1593
1594 ret = wl1271_rx_filter_clear_all(wl);
1595 if (ret)
1596 goto out;
1597
1598 /* Translate WoWLAN patterns into filters */
1599 for (i = 0; i < wow->n_patterns; i++) {
1600 struct cfg80211_pkt_pattern *p;
1601 struct wl12xx_rx_filter *filter = NULL;
1602
1603 p = &wow->patterns[i];
1604
1605 ret = wl1271_convert_wowlan_pattern_to_rx_filter(p, &filter);
1606 if (ret) {
1607 wl1271_warning("Failed to create an RX filter from "
1608 "wowlan pattern %d", i);
1609 goto out;
1610 }
1611
1612 ret = wl1271_rx_filter_enable(wl, i, 1, filter);
1613
1614 wl1271_rx_filter_free(filter);
1615 if (ret)
1616 goto out;
1617 }
1618
1619 ret = wl1271_acx_default_rx_filter_enable(wl, 1, FILTER_DROP);
1620
1621 out:
1622 return ret;
1623 }
1624
wl1271_configure_suspend_sta(struct wl1271 * wl,struct wl12xx_vif * wlvif,struct cfg80211_wowlan * wow)1625 static int wl1271_configure_suspend_sta(struct wl1271 *wl,
1626 struct wl12xx_vif *wlvif,
1627 struct cfg80211_wowlan *wow)
1628 {
1629 int ret = 0;
1630
1631 if (!test_bit(WLVIF_FLAG_STA_ASSOCIATED, &wlvif->flags))
1632 goto out;
1633
1634 ret = wl1271_configure_wowlan(wl, wow);
1635 if (ret < 0)
1636 goto out;
1637
1638 if ((wl->conf.conn.suspend_wake_up_event ==
1639 wl->conf.conn.wake_up_event) &&
1640 (wl->conf.conn.suspend_listen_interval ==
1641 wl->conf.conn.listen_interval))
1642 goto out;
1643
1644 ret = wl1271_acx_wake_up_conditions(wl, wlvif,
1645 wl->conf.conn.suspend_wake_up_event,
1646 wl->conf.conn.suspend_listen_interval);
1647
1648 if (ret < 0)
1649 wl1271_error("suspend: set wake up conditions failed: %d", ret);
1650 out:
1651 return ret;
1652
1653 }
1654
wl1271_configure_suspend_ap(struct wl1271 * wl,struct wl12xx_vif * wlvif,struct cfg80211_wowlan * wow)1655 static int wl1271_configure_suspend_ap(struct wl1271 *wl,
1656 struct wl12xx_vif *wlvif,
1657 struct cfg80211_wowlan *wow)
1658 {
1659 int ret = 0;
1660
1661 if (!test_bit(WLVIF_FLAG_AP_STARTED, &wlvif->flags))
1662 goto out;
1663
1664 ret = wl1271_acx_beacon_filter_opt(wl, wlvif, true);
1665 if (ret < 0)
1666 goto out;
1667
1668 ret = wl1271_configure_wowlan(wl, wow);
1669 if (ret < 0)
1670 goto out;
1671
1672 out:
1673 return ret;
1674
1675 }
1676
wl1271_configure_suspend(struct wl1271 * wl,struct wl12xx_vif * wlvif,struct cfg80211_wowlan * wow)1677 static int wl1271_configure_suspend(struct wl1271 *wl,
1678 struct wl12xx_vif *wlvif,
1679 struct cfg80211_wowlan *wow)
1680 {
1681 if (wlvif->bss_type == BSS_TYPE_STA_BSS)
1682 return wl1271_configure_suspend_sta(wl, wlvif, wow);
1683 if (wlvif->bss_type == BSS_TYPE_AP_BSS)
1684 return wl1271_configure_suspend_ap(wl, wlvif, wow);
1685 return 0;
1686 }
1687
wl1271_configure_resume(struct wl1271 * wl,struct wl12xx_vif * wlvif)1688 static void wl1271_configure_resume(struct wl1271 *wl, struct wl12xx_vif *wlvif)
1689 {
1690 int ret = 0;
1691 bool is_ap = wlvif->bss_type == BSS_TYPE_AP_BSS;
1692 bool is_sta = wlvif->bss_type == BSS_TYPE_STA_BSS;
1693
1694 if ((!is_ap) && (!is_sta))
1695 return;
1696
1697 if ((is_sta && !test_bit(WLVIF_FLAG_STA_ASSOCIATED, &wlvif->flags)) ||
1698 (is_ap && !test_bit(WLVIF_FLAG_AP_STARTED, &wlvif->flags)))
1699 return;
1700
1701 wl1271_configure_wowlan(wl, NULL);
1702
1703 if (is_sta) {
1704 if ((wl->conf.conn.suspend_wake_up_event ==
1705 wl->conf.conn.wake_up_event) &&
1706 (wl->conf.conn.suspend_listen_interval ==
1707 wl->conf.conn.listen_interval))
1708 return;
1709
1710 ret = wl1271_acx_wake_up_conditions(wl, wlvif,
1711 wl->conf.conn.wake_up_event,
1712 wl->conf.conn.listen_interval);
1713
1714 if (ret < 0)
1715 wl1271_error("resume: wake up conditions failed: %d",
1716 ret);
1717
1718 } else if (is_ap) {
1719 ret = wl1271_acx_beacon_filter_opt(wl, wlvif, false);
1720 }
1721 }
1722
wl1271_op_suspend(struct ieee80211_hw * hw,struct cfg80211_wowlan * wow)1723 static int __maybe_unused wl1271_op_suspend(struct ieee80211_hw *hw,
1724 struct cfg80211_wowlan *wow)
1725 {
1726 struct wl1271 *wl = hw->priv;
1727 struct wl12xx_vif *wlvif;
1728 unsigned long flags;
1729 int ret;
1730
1731 wl1271_debug(DEBUG_MAC80211, "mac80211 suspend wow=%d", !!wow);
1732 WARN_ON(!wow);
1733
1734 /* we want to perform the recovery before suspending */
1735 if (test_bit(WL1271_FLAG_RECOVERY_IN_PROGRESS, &wl->flags)) {
1736 wl1271_warning("postponing suspend to perform recovery");
1737 return -EBUSY;
1738 }
1739
1740 wl1271_tx_flush(wl);
1741
1742 mutex_lock(&wl->mutex);
1743
1744 ret = pm_runtime_get_sync(wl->dev);
1745 if (ret < 0) {
1746 pm_runtime_put_noidle(wl->dev);
1747 mutex_unlock(&wl->mutex);
1748 return ret;
1749 }
1750
1751 wl->wow_enabled = true;
1752 wl12xx_for_each_wlvif(wl, wlvif) {
1753 if (wlcore_is_p2p_mgmt(wlvif))
1754 continue;
1755
1756 ret = wl1271_configure_suspend(wl, wlvif, wow);
1757 if (ret < 0) {
1758 mutex_unlock(&wl->mutex);
1759 wl1271_warning("couldn't prepare device to suspend");
1760 return ret;
1761 }
1762 }
1763
1764 /* disable fast link flow control notifications from FW */
1765 ret = wlcore_hw_interrupt_notify(wl, false);
1766 if (ret < 0)
1767 goto out_sleep;
1768
1769 /* if filtering is enabled, configure the FW to drop all RX BA frames */
1770 ret = wlcore_hw_rx_ba_filter(wl,
1771 !!wl->conf.conn.suspend_rx_ba_activity);
1772 if (ret < 0)
1773 goto out_sleep;
1774
1775 out_sleep:
1776 pm_runtime_put_noidle(wl->dev);
1777 mutex_unlock(&wl->mutex);
1778
1779 if (ret < 0) {
1780 wl1271_warning("couldn't prepare device to suspend");
1781 return ret;
1782 }
1783
1784 /* flush any remaining work */
1785 wl1271_debug(DEBUG_MAC80211, "flushing remaining works");
1786
1787 flush_work(&wl->tx_work);
1788
1789 /*
1790 * Cancel the watchdog even if above tx_flush failed. We will detect
1791 * it on resume anyway.
1792 */
1793 cancel_delayed_work(&wl->tx_watchdog_work);
1794
1795 /*
1796 * set suspended flag to avoid triggering a new threaded_irq
1797 * work.
1798 */
1799 spin_lock_irqsave(&wl->wl_lock, flags);
1800 set_bit(WL1271_FLAG_SUSPENDED, &wl->flags);
1801 spin_unlock_irqrestore(&wl->wl_lock, flags);
1802
1803 return pm_runtime_force_suspend(wl->dev);
1804 }
1805
wl1271_op_resume(struct ieee80211_hw * hw)1806 static int __maybe_unused wl1271_op_resume(struct ieee80211_hw *hw)
1807 {
1808 struct wl1271 *wl = hw->priv;
1809 struct wl12xx_vif *wlvif;
1810 unsigned long flags;
1811 bool run_irq_work = false, pending_recovery;
1812 int ret;
1813
1814 wl1271_debug(DEBUG_MAC80211, "mac80211 resume wow=%d",
1815 wl->wow_enabled);
1816 WARN_ON(!wl->wow_enabled);
1817
1818 ret = pm_runtime_force_resume(wl->dev);
1819 if (ret < 0) {
1820 wl1271_error("ELP wakeup failure!");
1821 goto out_sleep;
1822 }
1823
1824 /*
1825 * re-enable irq_work enqueuing, and call irq_work directly if
1826 * there is a pending work.
1827 */
1828 spin_lock_irqsave(&wl->wl_lock, flags);
1829 clear_bit(WL1271_FLAG_SUSPENDED, &wl->flags);
1830 if (test_and_clear_bit(WL1271_FLAG_PENDING_WORK, &wl->flags))
1831 run_irq_work = true;
1832 spin_unlock_irqrestore(&wl->wl_lock, flags);
1833
1834 mutex_lock(&wl->mutex);
1835
1836 /* test the recovery flag before calling any SDIO functions */
1837 pending_recovery = test_bit(WL1271_FLAG_RECOVERY_IN_PROGRESS,
1838 &wl->flags);
1839
1840 if (run_irq_work) {
1841 wl1271_debug(DEBUG_MAC80211,
1842 "run postponed irq_work directly");
1843
1844 /* don't talk to the HW if recovery is pending */
1845 if (!pending_recovery) {
1846 ret = wlcore_irq_locked(wl);
1847 if (ret)
1848 wl12xx_queue_recovery_work(wl);
1849 }
1850
1851 wlcore_enable_interrupts(wl);
1852 }
1853
1854 if (pending_recovery) {
1855 wl1271_warning("queuing forgotten recovery on resume");
1856 ieee80211_queue_work(wl->hw, &wl->recovery_work);
1857 goto out_sleep;
1858 }
1859
1860 ret = pm_runtime_get_sync(wl->dev);
1861 if (ret < 0) {
1862 pm_runtime_put_noidle(wl->dev);
1863 goto out;
1864 }
1865
1866 wl12xx_for_each_wlvif(wl, wlvif) {
1867 if (wlcore_is_p2p_mgmt(wlvif))
1868 continue;
1869
1870 wl1271_configure_resume(wl, wlvif);
1871 }
1872
1873 ret = wlcore_hw_interrupt_notify(wl, true);
1874 if (ret < 0)
1875 goto out_sleep;
1876
1877 /* if filtering is enabled, configure the FW to drop all RX BA frames */
1878 ret = wlcore_hw_rx_ba_filter(wl, false);
1879 if (ret < 0)
1880 goto out_sleep;
1881
1882 out_sleep:
1883 pm_runtime_mark_last_busy(wl->dev);
1884 pm_runtime_put_autosuspend(wl->dev);
1885
1886 out:
1887 wl->wow_enabled = false;
1888
1889 /*
1890 * Set a flag to re-init the watchdog on the first Tx after resume.
1891 * That way we avoid possible conditions where Tx-complete interrupts
1892 * fail to arrive and we perform a spurious recovery.
1893 */
1894 set_bit(WL1271_FLAG_REINIT_TX_WDOG, &wl->flags);
1895 mutex_unlock(&wl->mutex);
1896
1897 return 0;
1898 }
1899
wl1271_op_start(struct ieee80211_hw * hw)1900 static int wl1271_op_start(struct ieee80211_hw *hw)
1901 {
1902 wl1271_debug(DEBUG_MAC80211, "mac80211 start");
1903
1904 /*
1905 * We have to delay the booting of the hardware because
1906 * we need to know the local MAC address before downloading and
1907 * initializing the firmware. The MAC address cannot be changed
1908 * after boot, and without the proper MAC address, the firmware
1909 * will not function properly.
1910 *
1911 * The MAC address is first known when the corresponding interface
1912 * is added. That is where we will initialize the hardware.
1913 */
1914
1915 return 0;
1916 }
1917
wlcore_op_stop_locked(struct wl1271 * wl)1918 static void wlcore_op_stop_locked(struct wl1271 *wl)
1919 {
1920 int i;
1921
1922 if (wl->state == WLCORE_STATE_OFF) {
1923 if (test_and_clear_bit(WL1271_FLAG_RECOVERY_IN_PROGRESS,
1924 &wl->flags))
1925 wlcore_enable_interrupts(wl);
1926
1927 return;
1928 }
1929
1930 /*
1931 * this must be before the cancel_work calls below, so that the work
1932 * functions don't perform further work.
1933 */
1934 wl->state = WLCORE_STATE_OFF;
1935
1936 /*
1937 * Use the nosync variant to disable interrupts, so the mutex could be
1938 * held while doing so without deadlocking.
1939 */
1940 wlcore_disable_interrupts_nosync(wl);
1941
1942 mutex_unlock(&wl->mutex);
1943
1944 wlcore_synchronize_interrupts(wl);
1945 if (!test_bit(WL1271_FLAG_RECOVERY_IN_PROGRESS, &wl->flags))
1946 cancel_work_sync(&wl->recovery_work);
1947 wl1271_flush_deferred_work(wl);
1948 cancel_delayed_work_sync(&wl->scan_complete_work);
1949 cancel_work_sync(&wl->netstack_work);
1950 cancel_work_sync(&wl->tx_work);
1951 cancel_delayed_work_sync(&wl->tx_watchdog_work);
1952
1953 /* let's notify MAC80211 about the remaining pending TX frames */
1954 mutex_lock(&wl->mutex);
1955 wl12xx_tx_reset(wl);
1956
1957 wl1271_power_off(wl);
1958 /*
1959 * In case a recovery was scheduled, interrupts were disabled to avoid
1960 * an interrupt storm. Now that the power is down, it is safe to
1961 * re-enable interrupts to balance the disable depth
1962 */
1963 if (test_and_clear_bit(WL1271_FLAG_RECOVERY_IN_PROGRESS, &wl->flags))
1964 wlcore_enable_interrupts(wl);
1965
1966 wl->band = NL80211_BAND_2GHZ;
1967
1968 wl->rx_counter = 0;
1969 wl->power_level = WL1271_DEFAULT_POWER_LEVEL;
1970 wl->channel_type = NL80211_CHAN_NO_HT;
1971 wl->tx_blocks_available = 0;
1972 wl->tx_allocated_blocks = 0;
1973 wl->tx_results_count = 0;
1974 wl->tx_packets_count = 0;
1975 wl->time_offset = 0;
1976 wl->ap_fw_ps_map = 0;
1977 wl->ap_ps_map = 0;
1978 wl->sleep_auth = WL1271_PSM_ILLEGAL;
1979 memset(wl->roles_map, 0, sizeof(wl->roles_map));
1980 memset(wl->links_map, 0, sizeof(wl->links_map));
1981 memset(wl->roc_map, 0, sizeof(wl->roc_map));
1982 memset(wl->session_ids, 0, sizeof(wl->session_ids));
1983 memset(wl->rx_filter_enabled, 0, sizeof(wl->rx_filter_enabled));
1984 wl->active_sta_count = 0;
1985 wl->active_link_count = 0;
1986
1987 /* The system link is always allocated */
1988 wl->links[WL12XX_SYSTEM_HLID].allocated_pkts = 0;
1989 wl->links[WL12XX_SYSTEM_HLID].prev_freed_pkts = 0;
1990 __set_bit(WL12XX_SYSTEM_HLID, wl->links_map);
1991
1992 /*
1993 * this is performed after the cancel_work calls and the associated
1994 * mutex_lock, so that wl1271_op_add_interface does not accidentally
1995 * get executed before all these vars have been reset.
1996 */
1997 wl->flags = 0;
1998
1999 wl->tx_blocks_freed = 0;
2000
2001 for (i = 0; i < NUM_TX_QUEUES; i++) {
2002 wl->tx_pkts_freed[i] = 0;
2003 wl->tx_allocated_pkts[i] = 0;
2004 }
2005
2006 wl1271_debugfs_reset(wl);
2007
2008 kfree(wl->raw_fw_status);
2009 wl->raw_fw_status = NULL;
2010 kfree(wl->fw_status);
2011 wl->fw_status = NULL;
2012 kfree(wl->tx_res_if);
2013 wl->tx_res_if = NULL;
2014 kfree(wl->target_mem_map);
2015 wl->target_mem_map = NULL;
2016
2017 /*
2018 * FW channels must be re-calibrated after recovery,
2019 * save current Reg-Domain channel configuration and clear it.
2020 */
2021 memcpy(wl->reg_ch_conf_pending, wl->reg_ch_conf_last,
2022 sizeof(wl->reg_ch_conf_pending));
2023 memset(wl->reg_ch_conf_last, 0, sizeof(wl->reg_ch_conf_last));
2024 }
2025
wlcore_op_stop(struct ieee80211_hw * hw)2026 static void wlcore_op_stop(struct ieee80211_hw *hw)
2027 {
2028 struct wl1271 *wl = hw->priv;
2029
2030 wl1271_debug(DEBUG_MAC80211, "mac80211 stop");
2031
2032 mutex_lock(&wl->mutex);
2033
2034 wlcore_op_stop_locked(wl);
2035
2036 mutex_unlock(&wl->mutex);
2037 }
2038
wlcore_channel_switch_work(struct work_struct * work)2039 static void wlcore_channel_switch_work(struct work_struct *work)
2040 {
2041 struct delayed_work *dwork;
2042 struct wl1271 *wl;
2043 struct ieee80211_vif *vif;
2044 struct wl12xx_vif *wlvif;
2045 int ret;
2046
2047 dwork = to_delayed_work(work);
2048 wlvif = container_of(dwork, struct wl12xx_vif, channel_switch_work);
2049 wl = wlvif->wl;
2050
2051 wl1271_info("channel switch failed (role_id: %d).", wlvif->role_id);
2052
2053 mutex_lock(&wl->mutex);
2054
2055 if (unlikely(wl->state != WLCORE_STATE_ON))
2056 goto out;
2057
2058 /* check the channel switch is still ongoing */
2059 if (!test_and_clear_bit(WLVIF_FLAG_CS_PROGRESS, &wlvif->flags))
2060 goto out;
2061
2062 vif = wl12xx_wlvif_to_vif(wlvif);
2063 ieee80211_chswitch_done(vif, false);
2064
2065 ret = pm_runtime_get_sync(wl->dev);
2066 if (ret < 0) {
2067 pm_runtime_put_noidle(wl->dev);
2068 goto out;
2069 }
2070
2071 wl12xx_cmd_stop_channel_switch(wl, wlvif);
2072
2073 pm_runtime_mark_last_busy(wl->dev);
2074 pm_runtime_put_autosuspend(wl->dev);
2075 out:
2076 mutex_unlock(&wl->mutex);
2077 }
2078
wlcore_connection_loss_work(struct work_struct * work)2079 static void wlcore_connection_loss_work(struct work_struct *work)
2080 {
2081 struct delayed_work *dwork;
2082 struct wl1271 *wl;
2083 struct ieee80211_vif *vif;
2084 struct wl12xx_vif *wlvif;
2085
2086 dwork = to_delayed_work(work);
2087 wlvif = container_of(dwork, struct wl12xx_vif, connection_loss_work);
2088 wl = wlvif->wl;
2089
2090 wl1271_info("Connection loss work (role_id: %d).", wlvif->role_id);
2091
2092 mutex_lock(&wl->mutex);
2093
2094 if (unlikely(wl->state != WLCORE_STATE_ON))
2095 goto out;
2096
2097 /* Call mac80211 connection loss */
2098 if (!test_bit(WLVIF_FLAG_STA_ASSOCIATED, &wlvif->flags))
2099 goto out;
2100
2101 vif = wl12xx_wlvif_to_vif(wlvif);
2102 ieee80211_connection_loss(vif);
2103 out:
2104 mutex_unlock(&wl->mutex);
2105 }
2106
wlcore_pending_auth_complete_work(struct work_struct * work)2107 static void wlcore_pending_auth_complete_work(struct work_struct *work)
2108 {
2109 struct delayed_work *dwork;
2110 struct wl1271 *wl;
2111 struct wl12xx_vif *wlvif;
2112 unsigned long time_spare;
2113 int ret;
2114
2115 dwork = to_delayed_work(work);
2116 wlvif = container_of(dwork, struct wl12xx_vif,
2117 pending_auth_complete_work);
2118 wl = wlvif->wl;
2119
2120 mutex_lock(&wl->mutex);
2121
2122 if (unlikely(wl->state != WLCORE_STATE_ON))
2123 goto out;
2124
2125 /*
2126 * Make sure a second really passed since the last auth reply. Maybe
2127 * a second auth reply arrived while we were stuck on the mutex.
2128 * Check for a little less than the timeout to protect from scheduler
2129 * irregularities.
2130 */
2131 time_spare = jiffies +
2132 msecs_to_jiffies(WLCORE_PEND_AUTH_ROC_TIMEOUT - 50);
2133 if (!time_after(time_spare, wlvif->pending_auth_reply_time))
2134 goto out;
2135
2136 ret = pm_runtime_get_sync(wl->dev);
2137 if (ret < 0) {
2138 pm_runtime_put_noidle(wl->dev);
2139 goto out;
2140 }
2141
2142 /* cancel the ROC if active */
2143 wlcore_update_inconn_sta(wl, wlvif, NULL, false);
2144
2145 pm_runtime_mark_last_busy(wl->dev);
2146 pm_runtime_put_autosuspend(wl->dev);
2147 out:
2148 mutex_unlock(&wl->mutex);
2149 }
2150
wl12xx_allocate_rate_policy(struct wl1271 * wl,u8 * idx)2151 static int wl12xx_allocate_rate_policy(struct wl1271 *wl, u8 *idx)
2152 {
2153 u8 policy = find_first_zero_bit(wl->rate_policies_map,
2154 WL12XX_MAX_RATE_POLICIES);
2155 if (policy >= WL12XX_MAX_RATE_POLICIES)
2156 return -EBUSY;
2157
2158 __set_bit(policy, wl->rate_policies_map);
2159 *idx = policy;
2160 return 0;
2161 }
2162
wl12xx_free_rate_policy(struct wl1271 * wl,u8 * idx)2163 static void wl12xx_free_rate_policy(struct wl1271 *wl, u8 *idx)
2164 {
2165 if (WARN_ON(*idx >= WL12XX_MAX_RATE_POLICIES))
2166 return;
2167
2168 __clear_bit(*idx, wl->rate_policies_map);
2169 *idx = WL12XX_MAX_RATE_POLICIES;
2170 }
2171
wlcore_allocate_klv_template(struct wl1271 * wl,u8 * idx)2172 static int wlcore_allocate_klv_template(struct wl1271 *wl, u8 *idx)
2173 {
2174 u8 policy = find_first_zero_bit(wl->klv_templates_map,
2175 WLCORE_MAX_KLV_TEMPLATES);
2176 if (policy >= WLCORE_MAX_KLV_TEMPLATES)
2177 return -EBUSY;
2178
2179 __set_bit(policy, wl->klv_templates_map);
2180 *idx = policy;
2181 return 0;
2182 }
2183
wlcore_free_klv_template(struct wl1271 * wl,u8 * idx)2184 static void wlcore_free_klv_template(struct wl1271 *wl, u8 *idx)
2185 {
2186 if (WARN_ON(*idx >= WLCORE_MAX_KLV_TEMPLATES))
2187 return;
2188
2189 __clear_bit(*idx, wl->klv_templates_map);
2190 *idx = WLCORE_MAX_KLV_TEMPLATES;
2191 }
2192
wl12xx_get_role_type(struct wl1271 * wl,struct wl12xx_vif * wlvif)2193 static u8 wl12xx_get_role_type(struct wl1271 *wl, struct wl12xx_vif *wlvif)
2194 {
2195 struct ieee80211_vif *vif = wl12xx_wlvif_to_vif(wlvif);
2196
2197 switch (wlvif->bss_type) {
2198 case BSS_TYPE_AP_BSS:
2199 if (wlvif->p2p)
2200 return WL1271_ROLE_P2P_GO;
2201 else if (ieee80211_vif_is_mesh(vif))
2202 return WL1271_ROLE_MESH_POINT;
2203 else
2204 return WL1271_ROLE_AP;
2205
2206 case BSS_TYPE_STA_BSS:
2207 if (wlvif->p2p)
2208 return WL1271_ROLE_P2P_CL;
2209 else
2210 return WL1271_ROLE_STA;
2211
2212 case BSS_TYPE_IBSS:
2213 return WL1271_ROLE_IBSS;
2214
2215 default:
2216 wl1271_error("invalid bss_type: %d", wlvif->bss_type);
2217 }
2218 return WL12XX_INVALID_ROLE_TYPE;
2219 }
2220
wl12xx_init_vif_data(struct wl1271 * wl,struct ieee80211_vif * vif)2221 static int wl12xx_init_vif_data(struct wl1271 *wl, struct ieee80211_vif *vif)
2222 {
2223 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
2224 int i;
2225
2226 /* clear everything but the persistent data */
2227 memset(wlvif, 0, offsetof(struct wl12xx_vif, persistent));
2228
2229 switch (ieee80211_vif_type_p2p(vif)) {
2230 case NL80211_IFTYPE_P2P_CLIENT:
2231 wlvif->p2p = 1;
2232 /* fall-through */
2233 case NL80211_IFTYPE_STATION:
2234 case NL80211_IFTYPE_P2P_DEVICE:
2235 wlvif->bss_type = BSS_TYPE_STA_BSS;
2236 break;
2237 case NL80211_IFTYPE_ADHOC:
2238 wlvif->bss_type = BSS_TYPE_IBSS;
2239 break;
2240 case NL80211_IFTYPE_P2P_GO:
2241 wlvif->p2p = 1;
2242 /* fall-through */
2243 case NL80211_IFTYPE_AP:
2244 case NL80211_IFTYPE_MESH_POINT:
2245 wlvif->bss_type = BSS_TYPE_AP_BSS;
2246 break;
2247 default:
2248 wlvif->bss_type = MAX_BSS_TYPE;
2249 return -EOPNOTSUPP;
2250 }
2251
2252 wlvif->role_id = WL12XX_INVALID_ROLE_ID;
2253 wlvif->dev_role_id = WL12XX_INVALID_ROLE_ID;
2254 wlvif->dev_hlid = WL12XX_INVALID_LINK_ID;
2255
2256 if (wlvif->bss_type == BSS_TYPE_STA_BSS ||
2257 wlvif->bss_type == BSS_TYPE_IBSS) {
2258 /* init sta/ibss data */
2259 wlvif->sta.hlid = WL12XX_INVALID_LINK_ID;
2260 wl12xx_allocate_rate_policy(wl, &wlvif->sta.basic_rate_idx);
2261 wl12xx_allocate_rate_policy(wl, &wlvif->sta.ap_rate_idx);
2262 wl12xx_allocate_rate_policy(wl, &wlvif->sta.p2p_rate_idx);
2263 wlcore_allocate_klv_template(wl, &wlvif->sta.klv_template_id);
2264 wlvif->basic_rate_set = CONF_TX_RATE_MASK_BASIC;
2265 wlvif->basic_rate = CONF_TX_RATE_MASK_BASIC;
2266 wlvif->rate_set = CONF_TX_RATE_MASK_BASIC;
2267 } else {
2268 /* init ap data */
2269 wlvif->ap.bcast_hlid = WL12XX_INVALID_LINK_ID;
2270 wlvif->ap.global_hlid = WL12XX_INVALID_LINK_ID;
2271 wl12xx_allocate_rate_policy(wl, &wlvif->ap.mgmt_rate_idx);
2272 wl12xx_allocate_rate_policy(wl, &wlvif->ap.bcast_rate_idx);
2273 for (i = 0; i < CONF_TX_MAX_AC_COUNT; i++)
2274 wl12xx_allocate_rate_policy(wl,
2275 &wlvif->ap.ucast_rate_idx[i]);
2276 wlvif->basic_rate_set = CONF_TX_ENABLED_RATES;
2277 /*
2278 * TODO: check if basic_rate shouldn't be
2279 * wl1271_tx_min_rate_get(wl, wlvif->basic_rate_set);
2280 * instead (the same thing for STA above).
2281 */
2282 wlvif->basic_rate = CONF_TX_ENABLED_RATES;
2283 /* TODO: this seems to be used only for STA, check it */
2284 wlvif->rate_set = CONF_TX_ENABLED_RATES;
2285 }
2286
2287 wlvif->bitrate_masks[NL80211_BAND_2GHZ] = wl->conf.tx.basic_rate;
2288 wlvif->bitrate_masks[NL80211_BAND_5GHZ] = wl->conf.tx.basic_rate_5;
2289 wlvif->beacon_int = WL1271_DEFAULT_BEACON_INT;
2290
2291 /*
2292 * mac80211 configures some values globally, while we treat them
2293 * per-interface. thus, on init, we have to copy them from wl
2294 */
2295 wlvif->band = wl->band;
2296 wlvif->channel = wl->channel;
2297 wlvif->power_level = wl->power_level;
2298 wlvif->channel_type = wl->channel_type;
2299
2300 INIT_WORK(&wlvif->rx_streaming_enable_work,
2301 wl1271_rx_streaming_enable_work);
2302 INIT_WORK(&wlvif->rx_streaming_disable_work,
2303 wl1271_rx_streaming_disable_work);
2304 INIT_WORK(&wlvif->rc_update_work, wlcore_rc_update_work);
2305 INIT_DELAYED_WORK(&wlvif->channel_switch_work,
2306 wlcore_channel_switch_work);
2307 INIT_DELAYED_WORK(&wlvif->connection_loss_work,
2308 wlcore_connection_loss_work);
2309 INIT_DELAYED_WORK(&wlvif->pending_auth_complete_work,
2310 wlcore_pending_auth_complete_work);
2311 INIT_LIST_HEAD(&wlvif->list);
2312
2313 timer_setup(&wlvif->rx_streaming_timer, wl1271_rx_streaming_timer, 0);
2314 return 0;
2315 }
2316
wl12xx_init_fw(struct wl1271 * wl)2317 static int wl12xx_init_fw(struct wl1271 *wl)
2318 {
2319 int retries = WL1271_BOOT_RETRIES;
2320 bool booted = false;
2321 struct wiphy *wiphy = wl->hw->wiphy;
2322 int ret;
2323
2324 while (retries) {
2325 retries--;
2326 ret = wl12xx_chip_wakeup(wl, false);
2327 if (ret < 0)
2328 goto power_off;
2329
2330 ret = wl->ops->boot(wl);
2331 if (ret < 0)
2332 goto power_off;
2333
2334 ret = wl1271_hw_init(wl);
2335 if (ret < 0)
2336 goto irq_disable;
2337
2338 booted = true;
2339 break;
2340
2341 irq_disable:
2342 mutex_unlock(&wl->mutex);
2343 /* Unlocking the mutex in the middle of handling is
2344 inherently unsafe. In this case we deem it safe to do,
2345 because we need to let any possibly pending IRQ out of
2346 the system (and while we are WLCORE_STATE_OFF the IRQ
2347 work function will not do anything.) Also, any other
2348 possible concurrent operations will fail due to the
2349 current state, hence the wl1271 struct should be safe. */
2350 wlcore_disable_interrupts(wl);
2351 wl1271_flush_deferred_work(wl);
2352 cancel_work_sync(&wl->netstack_work);
2353 mutex_lock(&wl->mutex);
2354 power_off:
2355 wl1271_power_off(wl);
2356 }
2357
2358 if (!booted) {
2359 wl1271_error("firmware boot failed despite %d retries",
2360 WL1271_BOOT_RETRIES);
2361 goto out;
2362 }
2363
2364 wl1271_info("firmware booted (%s)", wl->chip.fw_ver_str);
2365
2366 /* update hw/fw version info in wiphy struct */
2367 wiphy->hw_version = wl->chip.id;
2368 strncpy(wiphy->fw_version, wl->chip.fw_ver_str,
2369 sizeof(wiphy->fw_version));
2370
2371 /*
2372 * Now we know if 11a is supported (info from the NVS), so disable
2373 * 11a channels if not supported
2374 */
2375 if (!wl->enable_11a)
2376 wiphy->bands[NL80211_BAND_5GHZ]->n_channels = 0;
2377
2378 wl1271_debug(DEBUG_MAC80211, "11a is %ssupported",
2379 wl->enable_11a ? "" : "not ");
2380
2381 wl->state = WLCORE_STATE_ON;
2382 out:
2383 return ret;
2384 }
2385
wl12xx_dev_role_started(struct wl12xx_vif * wlvif)2386 static bool wl12xx_dev_role_started(struct wl12xx_vif *wlvif)
2387 {
2388 return wlvif->dev_hlid != WL12XX_INVALID_LINK_ID;
2389 }
2390
2391 /*
2392 * Check whether a fw switch (i.e. moving from one loaded
2393 * fw to another) is needed. This function is also responsible
2394 * for updating wl->last_vif_count, so it must be called before
2395 * loading a non-plt fw (so the correct fw (single-role/multi-role)
2396 * will be used).
2397 */
wl12xx_need_fw_change(struct wl1271 * wl,struct vif_counter_data vif_counter_data,bool add)2398 static bool wl12xx_need_fw_change(struct wl1271 *wl,
2399 struct vif_counter_data vif_counter_data,
2400 bool add)
2401 {
2402 enum wl12xx_fw_type current_fw = wl->fw_type;
2403 u8 vif_count = vif_counter_data.counter;
2404
2405 if (test_bit(WL1271_FLAG_VIF_CHANGE_IN_PROGRESS, &wl->flags))
2406 return false;
2407
2408 /* increase the vif count if this is a new vif */
2409 if (add && !vif_counter_data.cur_vif_running)
2410 vif_count++;
2411
2412 wl->last_vif_count = vif_count;
2413
2414 /* no need for fw change if the device is OFF */
2415 if (wl->state == WLCORE_STATE_OFF)
2416 return false;
2417
2418 /* no need for fw change if a single fw is used */
2419 if (!wl->mr_fw_name)
2420 return false;
2421
2422 if (vif_count > 1 && current_fw == WL12XX_FW_TYPE_NORMAL)
2423 return true;
2424 if (vif_count <= 1 && current_fw == WL12XX_FW_TYPE_MULTI)
2425 return true;
2426
2427 return false;
2428 }
2429
2430 /*
2431 * Enter "forced psm". Make sure the sta is in psm against the ap,
2432 * to make the fw switch a bit more disconnection-persistent.
2433 */
wl12xx_force_active_psm(struct wl1271 * wl)2434 static void wl12xx_force_active_psm(struct wl1271 *wl)
2435 {
2436 struct wl12xx_vif *wlvif;
2437
2438 wl12xx_for_each_wlvif_sta(wl, wlvif) {
2439 wl1271_ps_set_mode(wl, wlvif, STATION_POWER_SAVE_MODE);
2440 }
2441 }
2442
2443 struct wlcore_hw_queue_iter_data {
2444 unsigned long hw_queue_map[BITS_TO_LONGS(WLCORE_NUM_MAC_ADDRESSES)];
2445 /* current vif */
2446 struct ieee80211_vif *vif;
2447 /* is the current vif among those iterated */
2448 bool cur_running;
2449 };
2450
wlcore_hw_queue_iter(void * data,u8 * mac,struct ieee80211_vif * vif)2451 static void wlcore_hw_queue_iter(void *data, u8 *mac,
2452 struct ieee80211_vif *vif)
2453 {
2454 struct wlcore_hw_queue_iter_data *iter_data = data;
2455
2456 if (vif->type == NL80211_IFTYPE_P2P_DEVICE ||
2457 WARN_ON_ONCE(vif->hw_queue[0] == IEEE80211_INVAL_HW_QUEUE))
2458 return;
2459
2460 if (iter_data->cur_running || vif == iter_data->vif) {
2461 iter_data->cur_running = true;
2462 return;
2463 }
2464
2465 __set_bit(vif->hw_queue[0] / NUM_TX_QUEUES, iter_data->hw_queue_map);
2466 }
2467
wlcore_allocate_hw_queue_base(struct wl1271 * wl,struct wl12xx_vif * wlvif)2468 static int wlcore_allocate_hw_queue_base(struct wl1271 *wl,
2469 struct wl12xx_vif *wlvif)
2470 {
2471 struct ieee80211_vif *vif = wl12xx_wlvif_to_vif(wlvif);
2472 struct wlcore_hw_queue_iter_data iter_data = {};
2473 int i, q_base;
2474
2475 if (vif->type == NL80211_IFTYPE_P2P_DEVICE) {
2476 vif->cab_queue = IEEE80211_INVAL_HW_QUEUE;
2477 return 0;
2478 }
2479
2480 iter_data.vif = vif;
2481
2482 /* mark all bits taken by active interfaces */
2483 ieee80211_iterate_active_interfaces_atomic(wl->hw,
2484 IEEE80211_IFACE_ITER_RESUME_ALL,
2485 wlcore_hw_queue_iter, &iter_data);
2486
2487 /* the current vif is already running in mac80211 (resume/recovery) */
2488 if (iter_data.cur_running) {
2489 wlvif->hw_queue_base = vif->hw_queue[0];
2490 wl1271_debug(DEBUG_MAC80211,
2491 "using pre-allocated hw queue base %d",
2492 wlvif->hw_queue_base);
2493
2494 /* interface type might have changed type */
2495 goto adjust_cab_queue;
2496 }
2497
2498 q_base = find_first_zero_bit(iter_data.hw_queue_map,
2499 WLCORE_NUM_MAC_ADDRESSES);
2500 if (q_base >= WLCORE_NUM_MAC_ADDRESSES)
2501 return -EBUSY;
2502
2503 wlvif->hw_queue_base = q_base * NUM_TX_QUEUES;
2504 wl1271_debug(DEBUG_MAC80211, "allocating hw queue base: %d",
2505 wlvif->hw_queue_base);
2506
2507 for (i = 0; i < NUM_TX_QUEUES; i++) {
2508 wl->queue_stop_reasons[wlvif->hw_queue_base + i] = 0;
2509 /* register hw queues in mac80211 */
2510 vif->hw_queue[i] = wlvif->hw_queue_base + i;
2511 }
2512
2513 adjust_cab_queue:
2514 /* the last places are reserved for cab queues per interface */
2515 if (wlvif->bss_type == BSS_TYPE_AP_BSS)
2516 vif->cab_queue = NUM_TX_QUEUES * WLCORE_NUM_MAC_ADDRESSES +
2517 wlvif->hw_queue_base / NUM_TX_QUEUES;
2518 else
2519 vif->cab_queue = IEEE80211_INVAL_HW_QUEUE;
2520
2521 return 0;
2522 }
2523
wl1271_op_add_interface(struct ieee80211_hw * hw,struct ieee80211_vif * vif)2524 static int wl1271_op_add_interface(struct ieee80211_hw *hw,
2525 struct ieee80211_vif *vif)
2526 {
2527 struct wl1271 *wl = hw->priv;
2528 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
2529 struct vif_counter_data vif_count;
2530 int ret = 0;
2531 u8 role_type;
2532
2533 if (wl->plt) {
2534 wl1271_error("Adding Interface not allowed while in PLT mode");
2535 return -EBUSY;
2536 }
2537
2538 vif->driver_flags |= IEEE80211_VIF_BEACON_FILTER |
2539 IEEE80211_VIF_SUPPORTS_UAPSD |
2540 IEEE80211_VIF_SUPPORTS_CQM_RSSI;
2541
2542 wl1271_debug(DEBUG_MAC80211, "mac80211 add interface type %d mac %pM",
2543 ieee80211_vif_type_p2p(vif), vif->addr);
2544
2545 wl12xx_get_vif_count(hw, vif, &vif_count);
2546
2547 mutex_lock(&wl->mutex);
2548
2549 /*
2550 * in some very corner case HW recovery scenarios its possible to
2551 * get here before __wl1271_op_remove_interface is complete, so
2552 * opt out if that is the case.
2553 */
2554 if (test_bit(WL1271_FLAG_RECOVERY_IN_PROGRESS, &wl->flags) ||
2555 test_bit(WLVIF_FLAG_INITIALIZED, &wlvif->flags)) {
2556 ret = -EBUSY;
2557 goto out;
2558 }
2559
2560
2561 ret = wl12xx_init_vif_data(wl, vif);
2562 if (ret < 0)
2563 goto out;
2564
2565 wlvif->wl = wl;
2566 role_type = wl12xx_get_role_type(wl, wlvif);
2567 if (role_type == WL12XX_INVALID_ROLE_TYPE) {
2568 ret = -EINVAL;
2569 goto out;
2570 }
2571
2572 ret = wlcore_allocate_hw_queue_base(wl, wlvif);
2573 if (ret < 0)
2574 goto out;
2575
2576 /*
2577 * TODO: after the nvs issue will be solved, move this block
2578 * to start(), and make sure here the driver is ON.
2579 */
2580 if (wl->state == WLCORE_STATE_OFF) {
2581 /*
2582 * we still need this in order to configure the fw
2583 * while uploading the nvs
2584 */
2585 memcpy(wl->addresses[0].addr, vif->addr, ETH_ALEN);
2586
2587 ret = wl12xx_init_fw(wl);
2588 if (ret < 0)
2589 goto out;
2590 }
2591
2592 /*
2593 * Call runtime PM only after possible wl12xx_init_fw() above
2594 * is done. Otherwise we do not have interrupts enabled.
2595 */
2596 ret = pm_runtime_get_sync(wl->dev);
2597 if (ret < 0) {
2598 pm_runtime_put_noidle(wl->dev);
2599 goto out_unlock;
2600 }
2601
2602 if (wl12xx_need_fw_change(wl, vif_count, true)) {
2603 wl12xx_force_active_psm(wl);
2604 set_bit(WL1271_FLAG_INTENDED_FW_RECOVERY, &wl->flags);
2605 mutex_unlock(&wl->mutex);
2606 wl1271_recovery_work(&wl->recovery_work);
2607 return 0;
2608 }
2609
2610 if (!wlcore_is_p2p_mgmt(wlvif)) {
2611 ret = wl12xx_cmd_role_enable(wl, vif->addr,
2612 role_type, &wlvif->role_id);
2613 if (ret < 0)
2614 goto out;
2615
2616 ret = wl1271_init_vif_specific(wl, vif);
2617 if (ret < 0)
2618 goto out;
2619
2620 } else {
2621 ret = wl12xx_cmd_role_enable(wl, vif->addr, WL1271_ROLE_DEVICE,
2622 &wlvif->dev_role_id);
2623 if (ret < 0)
2624 goto out;
2625
2626 /* needed mainly for configuring rate policies */
2627 ret = wl1271_sta_hw_init(wl, wlvif);
2628 if (ret < 0)
2629 goto out;
2630 }
2631
2632 list_add(&wlvif->list, &wl->wlvif_list);
2633 set_bit(WLVIF_FLAG_INITIALIZED, &wlvif->flags);
2634
2635 if (wlvif->bss_type == BSS_TYPE_AP_BSS)
2636 wl->ap_count++;
2637 else
2638 wl->sta_count++;
2639 out:
2640 pm_runtime_mark_last_busy(wl->dev);
2641 pm_runtime_put_autosuspend(wl->dev);
2642 out_unlock:
2643 mutex_unlock(&wl->mutex);
2644
2645 return ret;
2646 }
2647
__wl1271_op_remove_interface(struct wl1271 * wl,struct ieee80211_vif * vif,bool reset_tx_queues)2648 static void __wl1271_op_remove_interface(struct wl1271 *wl,
2649 struct ieee80211_vif *vif,
2650 bool reset_tx_queues)
2651 {
2652 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
2653 int i, ret;
2654 bool is_ap = (wlvif->bss_type == BSS_TYPE_AP_BSS);
2655
2656 wl1271_debug(DEBUG_MAC80211, "mac80211 remove interface");
2657
2658 if (!test_and_clear_bit(WLVIF_FLAG_INITIALIZED, &wlvif->flags))
2659 return;
2660
2661 /* because of hardware recovery, we may get here twice */
2662 if (wl->state == WLCORE_STATE_OFF)
2663 return;
2664
2665 wl1271_info("down");
2666
2667 if (wl->scan.state != WL1271_SCAN_STATE_IDLE &&
2668 wl->scan_wlvif == wlvif) {
2669 struct cfg80211_scan_info info = {
2670 .aborted = true,
2671 };
2672
2673 /*
2674 * Rearm the tx watchdog just before idling scan. This
2675 * prevents just-finished scans from triggering the watchdog
2676 */
2677 wl12xx_rearm_tx_watchdog_locked(wl);
2678
2679 wl->scan.state = WL1271_SCAN_STATE_IDLE;
2680 memset(wl->scan.scanned_ch, 0, sizeof(wl->scan.scanned_ch));
2681 wl->scan_wlvif = NULL;
2682 wl->scan.req = NULL;
2683 ieee80211_scan_completed(wl->hw, &info);
2684 }
2685
2686 if (wl->sched_vif == wlvif)
2687 wl->sched_vif = NULL;
2688
2689 if (wl->roc_vif == vif) {
2690 wl->roc_vif = NULL;
2691 ieee80211_remain_on_channel_expired(wl->hw);
2692 }
2693
2694 if (!test_bit(WL1271_FLAG_RECOVERY_IN_PROGRESS, &wl->flags)) {
2695 /* disable active roles */
2696 ret = pm_runtime_get_sync(wl->dev);
2697 if (ret < 0) {
2698 pm_runtime_put_noidle(wl->dev);
2699 goto deinit;
2700 }
2701
2702 if (wlvif->bss_type == BSS_TYPE_STA_BSS ||
2703 wlvif->bss_type == BSS_TYPE_IBSS) {
2704 if (wl12xx_dev_role_started(wlvif))
2705 wl12xx_stop_dev(wl, wlvif);
2706 }
2707
2708 if (!wlcore_is_p2p_mgmt(wlvif)) {
2709 ret = wl12xx_cmd_role_disable(wl, &wlvif->role_id);
2710 if (ret < 0)
2711 goto deinit;
2712 } else {
2713 ret = wl12xx_cmd_role_disable(wl, &wlvif->dev_role_id);
2714 if (ret < 0)
2715 goto deinit;
2716 }
2717
2718 pm_runtime_mark_last_busy(wl->dev);
2719 pm_runtime_put_autosuspend(wl->dev);
2720 }
2721 deinit:
2722 wl12xx_tx_reset_wlvif(wl, wlvif);
2723
2724 /* clear all hlids (except system_hlid) */
2725 wlvif->dev_hlid = WL12XX_INVALID_LINK_ID;
2726
2727 if (wlvif->bss_type == BSS_TYPE_STA_BSS ||
2728 wlvif->bss_type == BSS_TYPE_IBSS) {
2729 wlvif->sta.hlid = WL12XX_INVALID_LINK_ID;
2730 wl12xx_free_rate_policy(wl, &wlvif->sta.basic_rate_idx);
2731 wl12xx_free_rate_policy(wl, &wlvif->sta.ap_rate_idx);
2732 wl12xx_free_rate_policy(wl, &wlvif->sta.p2p_rate_idx);
2733 wlcore_free_klv_template(wl, &wlvif->sta.klv_template_id);
2734 } else {
2735 wlvif->ap.bcast_hlid = WL12XX_INVALID_LINK_ID;
2736 wlvif->ap.global_hlid = WL12XX_INVALID_LINK_ID;
2737 wl12xx_free_rate_policy(wl, &wlvif->ap.mgmt_rate_idx);
2738 wl12xx_free_rate_policy(wl, &wlvif->ap.bcast_rate_idx);
2739 for (i = 0; i < CONF_TX_MAX_AC_COUNT; i++)
2740 wl12xx_free_rate_policy(wl,
2741 &wlvif->ap.ucast_rate_idx[i]);
2742 wl1271_free_ap_keys(wl, wlvif);
2743 }
2744
2745 dev_kfree_skb(wlvif->probereq);
2746 wlvif->probereq = NULL;
2747 if (wl->last_wlvif == wlvif)
2748 wl->last_wlvif = NULL;
2749 list_del(&wlvif->list);
2750 memset(wlvif->ap.sta_hlid_map, 0, sizeof(wlvif->ap.sta_hlid_map));
2751 wlvif->role_id = WL12XX_INVALID_ROLE_ID;
2752 wlvif->dev_role_id = WL12XX_INVALID_ROLE_ID;
2753
2754 if (is_ap)
2755 wl->ap_count--;
2756 else
2757 wl->sta_count--;
2758
2759 /*
2760 * Last AP, have more stations. Configure sleep auth according to STA.
2761 * Don't do thin on unintended recovery.
2762 */
2763 if (test_bit(WL1271_FLAG_RECOVERY_IN_PROGRESS, &wl->flags) &&
2764 !test_bit(WL1271_FLAG_INTENDED_FW_RECOVERY, &wl->flags))
2765 goto unlock;
2766
2767 if (wl->ap_count == 0 && is_ap) {
2768 /* mask ap events */
2769 wl->event_mask &= ~wl->ap_event_mask;
2770 wl1271_event_unmask(wl);
2771 }
2772
2773 if (wl->ap_count == 0 && is_ap && wl->sta_count) {
2774 u8 sta_auth = wl->conf.conn.sta_sleep_auth;
2775 /* Configure for power according to debugfs */
2776 if (sta_auth != WL1271_PSM_ILLEGAL)
2777 wl1271_acx_sleep_auth(wl, sta_auth);
2778 /* Configure for ELP power saving */
2779 else
2780 wl1271_acx_sleep_auth(wl, WL1271_PSM_ELP);
2781 }
2782
2783 unlock:
2784 mutex_unlock(&wl->mutex);
2785
2786 del_timer_sync(&wlvif->rx_streaming_timer);
2787 cancel_work_sync(&wlvif->rx_streaming_enable_work);
2788 cancel_work_sync(&wlvif->rx_streaming_disable_work);
2789 cancel_work_sync(&wlvif->rc_update_work);
2790 cancel_delayed_work_sync(&wlvif->connection_loss_work);
2791 cancel_delayed_work_sync(&wlvif->channel_switch_work);
2792 cancel_delayed_work_sync(&wlvif->pending_auth_complete_work);
2793
2794 mutex_lock(&wl->mutex);
2795 }
2796
wl1271_op_remove_interface(struct ieee80211_hw * hw,struct ieee80211_vif * vif)2797 static void wl1271_op_remove_interface(struct ieee80211_hw *hw,
2798 struct ieee80211_vif *vif)
2799 {
2800 struct wl1271 *wl = hw->priv;
2801 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
2802 struct wl12xx_vif *iter;
2803 struct vif_counter_data vif_count;
2804
2805 wl12xx_get_vif_count(hw, vif, &vif_count);
2806 mutex_lock(&wl->mutex);
2807
2808 if (wl->state == WLCORE_STATE_OFF ||
2809 !test_bit(WLVIF_FLAG_INITIALIZED, &wlvif->flags))
2810 goto out;
2811
2812 /*
2813 * wl->vif can be null here if someone shuts down the interface
2814 * just when hardware recovery has been started.
2815 */
2816 wl12xx_for_each_wlvif(wl, iter) {
2817 if (iter != wlvif)
2818 continue;
2819
2820 __wl1271_op_remove_interface(wl, vif, true);
2821 break;
2822 }
2823 WARN_ON(iter != wlvif);
2824 if (wl12xx_need_fw_change(wl, vif_count, false)) {
2825 wl12xx_force_active_psm(wl);
2826 set_bit(WL1271_FLAG_INTENDED_FW_RECOVERY, &wl->flags);
2827 wl12xx_queue_recovery_work(wl);
2828 }
2829 out:
2830 mutex_unlock(&wl->mutex);
2831 }
2832
wl12xx_op_change_interface(struct ieee80211_hw * hw,struct ieee80211_vif * vif,enum nl80211_iftype new_type,bool p2p)2833 static int wl12xx_op_change_interface(struct ieee80211_hw *hw,
2834 struct ieee80211_vif *vif,
2835 enum nl80211_iftype new_type, bool p2p)
2836 {
2837 struct wl1271 *wl = hw->priv;
2838 int ret;
2839
2840 set_bit(WL1271_FLAG_VIF_CHANGE_IN_PROGRESS, &wl->flags);
2841 wl1271_op_remove_interface(hw, vif);
2842
2843 vif->type = new_type;
2844 vif->p2p = p2p;
2845 ret = wl1271_op_add_interface(hw, vif);
2846
2847 clear_bit(WL1271_FLAG_VIF_CHANGE_IN_PROGRESS, &wl->flags);
2848 return ret;
2849 }
2850
wlcore_join(struct wl1271 * wl,struct wl12xx_vif * wlvif)2851 static int wlcore_join(struct wl1271 *wl, struct wl12xx_vif *wlvif)
2852 {
2853 int ret;
2854 bool is_ibss = (wlvif->bss_type == BSS_TYPE_IBSS);
2855
2856 /*
2857 * One of the side effects of the JOIN command is that is clears
2858 * WPA/WPA2 keys from the chipset. Performing a JOIN while associated
2859 * to a WPA/WPA2 access point will therefore kill the data-path.
2860 * Currently the only valid scenario for JOIN during association
2861 * is on roaming, in which case we will also be given new keys.
2862 * Keep the below message for now, unless it starts bothering
2863 * users who really like to roam a lot :)
2864 */
2865 if (test_bit(WLVIF_FLAG_STA_ASSOCIATED, &wlvif->flags))
2866 wl1271_info("JOIN while associated.");
2867
2868 /* clear encryption type */
2869 wlvif->encryption_type = KEY_NONE;
2870
2871 if (is_ibss)
2872 ret = wl12xx_cmd_role_start_ibss(wl, wlvif);
2873 else {
2874 if (wl->quirks & WLCORE_QUIRK_START_STA_FAILS) {
2875 /*
2876 * TODO: this is an ugly workaround for wl12xx fw
2877 * bug - we are not able to tx/rx after the first
2878 * start_sta, so make dummy start+stop calls,
2879 * and then call start_sta again.
2880 * this should be fixed in the fw.
2881 */
2882 wl12xx_cmd_role_start_sta(wl, wlvif);
2883 wl12xx_cmd_role_stop_sta(wl, wlvif);
2884 }
2885
2886 ret = wl12xx_cmd_role_start_sta(wl, wlvif);
2887 }
2888
2889 return ret;
2890 }
2891
wl1271_ssid_set(struct wl12xx_vif * wlvif,struct sk_buff * skb,int offset)2892 static int wl1271_ssid_set(struct wl12xx_vif *wlvif, struct sk_buff *skb,
2893 int offset)
2894 {
2895 u8 ssid_len;
2896 const u8 *ptr = cfg80211_find_ie(WLAN_EID_SSID, skb->data + offset,
2897 skb->len - offset);
2898
2899 if (!ptr) {
2900 wl1271_error("No SSID in IEs!");
2901 return -ENOENT;
2902 }
2903
2904 ssid_len = ptr[1];
2905 if (ssid_len > IEEE80211_MAX_SSID_LEN) {
2906 wl1271_error("SSID is too long!");
2907 return -EINVAL;
2908 }
2909
2910 wlvif->ssid_len = ssid_len;
2911 memcpy(wlvif->ssid, ptr+2, ssid_len);
2912 return 0;
2913 }
2914
wlcore_set_ssid(struct wl1271 * wl,struct wl12xx_vif * wlvif)2915 static int wlcore_set_ssid(struct wl1271 *wl, struct wl12xx_vif *wlvif)
2916 {
2917 struct ieee80211_vif *vif = wl12xx_wlvif_to_vif(wlvif);
2918 struct sk_buff *skb;
2919 int ieoffset;
2920
2921 /* we currently only support setting the ssid from the ap probe req */
2922 if (wlvif->bss_type != BSS_TYPE_STA_BSS)
2923 return -EINVAL;
2924
2925 skb = ieee80211_ap_probereq_get(wl->hw, vif);
2926 if (!skb)
2927 return -EINVAL;
2928
2929 ieoffset = offsetof(struct ieee80211_mgmt,
2930 u.probe_req.variable);
2931 wl1271_ssid_set(wlvif, skb, ieoffset);
2932 dev_kfree_skb(skb);
2933
2934 return 0;
2935 }
2936
wlcore_set_assoc(struct wl1271 * wl,struct wl12xx_vif * wlvif,struct ieee80211_bss_conf * bss_conf,u32 sta_rate_set)2937 static int wlcore_set_assoc(struct wl1271 *wl, struct wl12xx_vif *wlvif,
2938 struct ieee80211_bss_conf *bss_conf,
2939 u32 sta_rate_set)
2940 {
2941 int ieoffset;
2942 int ret;
2943
2944 wlvif->aid = bss_conf->aid;
2945 wlvif->channel_type = cfg80211_get_chandef_type(&bss_conf->chandef);
2946 wlvif->beacon_int = bss_conf->beacon_int;
2947 wlvif->wmm_enabled = bss_conf->qos;
2948
2949 set_bit(WLVIF_FLAG_STA_ASSOCIATED, &wlvif->flags);
2950
2951 /*
2952 * with wl1271, we don't need to update the
2953 * beacon_int and dtim_period, because the firmware
2954 * updates it by itself when the first beacon is
2955 * received after a join.
2956 */
2957 ret = wl1271_cmd_build_ps_poll(wl, wlvif, wlvif->aid);
2958 if (ret < 0)
2959 return ret;
2960
2961 /*
2962 * Get a template for hardware connection maintenance
2963 */
2964 dev_kfree_skb(wlvif->probereq);
2965 wlvif->probereq = wl1271_cmd_build_ap_probe_req(wl,
2966 wlvif,
2967 NULL);
2968 ieoffset = offsetof(struct ieee80211_mgmt,
2969 u.probe_req.variable);
2970 wl1271_ssid_set(wlvif, wlvif->probereq, ieoffset);
2971
2972 /* enable the connection monitoring feature */
2973 ret = wl1271_acx_conn_monit_params(wl, wlvif, true);
2974 if (ret < 0)
2975 return ret;
2976
2977 /*
2978 * The join command disable the keep-alive mode, shut down its process,
2979 * and also clear the template config, so we need to reset it all after
2980 * the join. The acx_aid starts the keep-alive process, and the order
2981 * of the commands below is relevant.
2982 */
2983 ret = wl1271_acx_keep_alive_mode(wl, wlvif, true);
2984 if (ret < 0)
2985 return ret;
2986
2987 ret = wl1271_acx_aid(wl, wlvif, wlvif->aid);
2988 if (ret < 0)
2989 return ret;
2990
2991 ret = wl12xx_cmd_build_klv_null_data(wl, wlvif);
2992 if (ret < 0)
2993 return ret;
2994
2995 ret = wl1271_acx_keep_alive_config(wl, wlvif,
2996 wlvif->sta.klv_template_id,
2997 ACX_KEEP_ALIVE_TPL_VALID);
2998 if (ret < 0)
2999 return ret;
3000
3001 /*
3002 * The default fw psm configuration is AUTO, while mac80211 default
3003 * setting is off (ACTIVE), so sync the fw with the correct value.
3004 */
3005 ret = wl1271_ps_set_mode(wl, wlvif, STATION_ACTIVE_MODE);
3006 if (ret < 0)
3007 return ret;
3008
3009 if (sta_rate_set) {
3010 wlvif->rate_set =
3011 wl1271_tx_enabled_rates_get(wl,
3012 sta_rate_set,
3013 wlvif->band);
3014 ret = wl1271_acx_sta_rate_policies(wl, wlvif);
3015 if (ret < 0)
3016 return ret;
3017 }
3018
3019 return ret;
3020 }
3021
wlcore_unset_assoc(struct wl1271 * wl,struct wl12xx_vif * wlvif)3022 static int wlcore_unset_assoc(struct wl1271 *wl, struct wl12xx_vif *wlvif)
3023 {
3024 int ret;
3025 bool sta = wlvif->bss_type == BSS_TYPE_STA_BSS;
3026
3027 /* make sure we are connected (sta) joined */
3028 if (sta &&
3029 !test_and_clear_bit(WLVIF_FLAG_STA_ASSOCIATED, &wlvif->flags))
3030 return false;
3031
3032 /* make sure we are joined (ibss) */
3033 if (!sta &&
3034 test_and_clear_bit(WLVIF_FLAG_IBSS_JOINED, &wlvif->flags))
3035 return false;
3036
3037 if (sta) {
3038 /* use defaults when not associated */
3039 wlvif->aid = 0;
3040
3041 /* free probe-request template */
3042 dev_kfree_skb(wlvif->probereq);
3043 wlvif->probereq = NULL;
3044
3045 /* disable connection monitor features */
3046 ret = wl1271_acx_conn_monit_params(wl, wlvif, false);
3047 if (ret < 0)
3048 return ret;
3049
3050 /* Disable the keep-alive feature */
3051 ret = wl1271_acx_keep_alive_mode(wl, wlvif, false);
3052 if (ret < 0)
3053 return ret;
3054
3055 /* disable beacon filtering */
3056 ret = wl1271_acx_beacon_filter_opt(wl, wlvif, false);
3057 if (ret < 0)
3058 return ret;
3059 }
3060
3061 if (test_and_clear_bit(WLVIF_FLAG_CS_PROGRESS, &wlvif->flags)) {
3062 struct ieee80211_vif *vif = wl12xx_wlvif_to_vif(wlvif);
3063
3064 wl12xx_cmd_stop_channel_switch(wl, wlvif);
3065 ieee80211_chswitch_done(vif, false);
3066 cancel_delayed_work(&wlvif->channel_switch_work);
3067 }
3068
3069 /* invalidate keep-alive template */
3070 wl1271_acx_keep_alive_config(wl, wlvif,
3071 wlvif->sta.klv_template_id,
3072 ACX_KEEP_ALIVE_TPL_INVALID);
3073
3074 return 0;
3075 }
3076
wl1271_set_band_rate(struct wl1271 * wl,struct wl12xx_vif * wlvif)3077 static void wl1271_set_band_rate(struct wl1271 *wl, struct wl12xx_vif *wlvif)
3078 {
3079 wlvif->basic_rate_set = wlvif->bitrate_masks[wlvif->band];
3080 wlvif->rate_set = wlvif->basic_rate_set;
3081 }
3082
wl1271_sta_handle_idle(struct wl1271 * wl,struct wl12xx_vif * wlvif,bool idle)3083 static void wl1271_sta_handle_idle(struct wl1271 *wl, struct wl12xx_vif *wlvif,
3084 bool idle)
3085 {
3086 bool cur_idle = !test_bit(WLVIF_FLAG_ACTIVE, &wlvif->flags);
3087
3088 if (idle == cur_idle)
3089 return;
3090
3091 if (idle) {
3092 clear_bit(WLVIF_FLAG_ACTIVE, &wlvif->flags);
3093 } else {
3094 /* The current firmware only supports sched_scan in idle */
3095 if (wl->sched_vif == wlvif)
3096 wl->ops->sched_scan_stop(wl, wlvif);
3097
3098 set_bit(WLVIF_FLAG_ACTIVE, &wlvif->flags);
3099 }
3100 }
3101
wl12xx_config_vif(struct wl1271 * wl,struct wl12xx_vif * wlvif,struct ieee80211_conf * conf,u32 changed)3102 static int wl12xx_config_vif(struct wl1271 *wl, struct wl12xx_vif *wlvif,
3103 struct ieee80211_conf *conf, u32 changed)
3104 {
3105 int ret;
3106
3107 if (wlcore_is_p2p_mgmt(wlvif))
3108 return 0;
3109
3110 if (conf->power_level != wlvif->power_level) {
3111 ret = wl1271_acx_tx_power(wl, wlvif, conf->power_level);
3112 if (ret < 0)
3113 return ret;
3114
3115 wlvif->power_level = conf->power_level;
3116 }
3117
3118 return 0;
3119 }
3120
wl1271_op_config(struct ieee80211_hw * hw,u32 changed)3121 static int wl1271_op_config(struct ieee80211_hw *hw, u32 changed)
3122 {
3123 struct wl1271 *wl = hw->priv;
3124 struct wl12xx_vif *wlvif;
3125 struct ieee80211_conf *conf = &hw->conf;
3126 int ret = 0;
3127
3128 wl1271_debug(DEBUG_MAC80211, "mac80211 config psm %s power %d %s"
3129 " changed 0x%x",
3130 conf->flags & IEEE80211_CONF_PS ? "on" : "off",
3131 conf->power_level,
3132 conf->flags & IEEE80211_CONF_IDLE ? "idle" : "in use",
3133 changed);
3134
3135 mutex_lock(&wl->mutex);
3136
3137 if (changed & IEEE80211_CONF_CHANGE_POWER)
3138 wl->power_level = conf->power_level;
3139
3140 if (unlikely(wl->state != WLCORE_STATE_ON))
3141 goto out;
3142
3143 ret = pm_runtime_get_sync(wl->dev);
3144 if (ret < 0) {
3145 pm_runtime_put_noidle(wl->dev);
3146 goto out;
3147 }
3148
3149 /* configure each interface */
3150 wl12xx_for_each_wlvif(wl, wlvif) {
3151 ret = wl12xx_config_vif(wl, wlvif, conf, changed);
3152 if (ret < 0)
3153 goto out_sleep;
3154 }
3155
3156 out_sleep:
3157 pm_runtime_mark_last_busy(wl->dev);
3158 pm_runtime_put_autosuspend(wl->dev);
3159
3160 out:
3161 mutex_unlock(&wl->mutex);
3162
3163 return ret;
3164 }
3165
3166 struct wl1271_filter_params {
3167 bool enabled;
3168 int mc_list_length;
3169 u8 mc_list[ACX_MC_ADDRESS_GROUP_MAX][ETH_ALEN];
3170 };
3171
wl1271_op_prepare_multicast(struct ieee80211_hw * hw,struct netdev_hw_addr_list * mc_list)3172 static u64 wl1271_op_prepare_multicast(struct ieee80211_hw *hw,
3173 struct netdev_hw_addr_list *mc_list)
3174 {
3175 struct wl1271_filter_params *fp;
3176 struct netdev_hw_addr *ha;
3177
3178 fp = kzalloc(sizeof(*fp), GFP_ATOMIC);
3179 if (!fp) {
3180 wl1271_error("Out of memory setting filters.");
3181 return 0;
3182 }
3183
3184 /* update multicast filtering parameters */
3185 fp->mc_list_length = 0;
3186 if (netdev_hw_addr_list_count(mc_list) > ACX_MC_ADDRESS_GROUP_MAX) {
3187 fp->enabled = false;
3188 } else {
3189 fp->enabled = true;
3190 netdev_hw_addr_list_for_each(ha, mc_list) {
3191 memcpy(fp->mc_list[fp->mc_list_length],
3192 ha->addr, ETH_ALEN);
3193 fp->mc_list_length++;
3194 }
3195 }
3196
3197 return (u64)(unsigned long)fp;
3198 }
3199
3200 #define WL1271_SUPPORTED_FILTERS (FIF_ALLMULTI | \
3201 FIF_FCSFAIL | \
3202 FIF_BCN_PRBRESP_PROMISC | \
3203 FIF_CONTROL | \
3204 FIF_OTHER_BSS)
3205
wl1271_op_configure_filter(struct ieee80211_hw * hw,unsigned int changed,unsigned int * total,u64 multicast)3206 static void wl1271_op_configure_filter(struct ieee80211_hw *hw,
3207 unsigned int changed,
3208 unsigned int *total, u64 multicast)
3209 {
3210 struct wl1271_filter_params *fp = (void *)(unsigned long)multicast;
3211 struct wl1271 *wl = hw->priv;
3212 struct wl12xx_vif *wlvif;
3213
3214 int ret;
3215
3216 wl1271_debug(DEBUG_MAC80211, "mac80211 configure filter changed %x"
3217 " total %x", changed, *total);
3218
3219 mutex_lock(&wl->mutex);
3220
3221 *total &= WL1271_SUPPORTED_FILTERS;
3222 changed &= WL1271_SUPPORTED_FILTERS;
3223
3224 if (unlikely(wl->state != WLCORE_STATE_ON))
3225 goto out;
3226
3227 ret = pm_runtime_get_sync(wl->dev);
3228 if (ret < 0) {
3229 pm_runtime_put_noidle(wl->dev);
3230 goto out;
3231 }
3232
3233 wl12xx_for_each_wlvif(wl, wlvif) {
3234 if (wlcore_is_p2p_mgmt(wlvif))
3235 continue;
3236
3237 if (wlvif->bss_type != BSS_TYPE_AP_BSS) {
3238 if (*total & FIF_ALLMULTI)
3239 ret = wl1271_acx_group_address_tbl(wl, wlvif,
3240 false,
3241 NULL, 0);
3242 else if (fp)
3243 ret = wl1271_acx_group_address_tbl(wl, wlvif,
3244 fp->enabled,
3245 fp->mc_list,
3246 fp->mc_list_length);
3247 if (ret < 0)
3248 goto out_sleep;
3249 }
3250
3251 /*
3252 * If interface in AP mode and created with allmulticast then disable
3253 * the firmware filters so that all multicast packets are passed
3254 * This is mandatory for MDNS based discovery protocols
3255 */
3256 if (wlvif->bss_type == BSS_TYPE_AP_BSS) {
3257 if (*total & FIF_ALLMULTI) {
3258 ret = wl1271_acx_group_address_tbl(wl, wlvif,
3259 false,
3260 NULL, 0);
3261 if (ret < 0)
3262 goto out_sleep;
3263 }
3264 }
3265 }
3266
3267 /*
3268 * the fw doesn't provide an api to configure the filters. instead,
3269 * the filters configuration is based on the active roles / ROC
3270 * state.
3271 */
3272
3273 out_sleep:
3274 pm_runtime_mark_last_busy(wl->dev);
3275 pm_runtime_put_autosuspend(wl->dev);
3276
3277 out:
3278 mutex_unlock(&wl->mutex);
3279 kfree(fp);
3280 }
3281
wl1271_record_ap_key(struct wl1271 * wl,struct wl12xx_vif * wlvif,u8 id,u8 key_type,u8 key_size,const u8 * key,u8 hlid,u32 tx_seq_32,u16 tx_seq_16)3282 static int wl1271_record_ap_key(struct wl1271 *wl, struct wl12xx_vif *wlvif,
3283 u8 id, u8 key_type, u8 key_size,
3284 const u8 *key, u8 hlid, u32 tx_seq_32,
3285 u16 tx_seq_16)
3286 {
3287 struct wl1271_ap_key *ap_key;
3288 int i;
3289
3290 wl1271_debug(DEBUG_CRYPT, "record ap key id %d", (int)id);
3291
3292 if (key_size > MAX_KEY_SIZE)
3293 return -EINVAL;
3294
3295 /*
3296 * Find next free entry in ap_keys. Also check we are not replacing
3297 * an existing key.
3298 */
3299 for (i = 0; i < MAX_NUM_KEYS; i++) {
3300 if (wlvif->ap.recorded_keys[i] == NULL)
3301 break;
3302
3303 if (wlvif->ap.recorded_keys[i]->id == id) {
3304 wl1271_warning("trying to record key replacement");
3305 return -EINVAL;
3306 }
3307 }
3308
3309 if (i == MAX_NUM_KEYS)
3310 return -EBUSY;
3311
3312 ap_key = kzalloc(sizeof(*ap_key), GFP_KERNEL);
3313 if (!ap_key)
3314 return -ENOMEM;
3315
3316 ap_key->id = id;
3317 ap_key->key_type = key_type;
3318 ap_key->key_size = key_size;
3319 memcpy(ap_key->key, key, key_size);
3320 ap_key->hlid = hlid;
3321 ap_key->tx_seq_32 = tx_seq_32;
3322 ap_key->tx_seq_16 = tx_seq_16;
3323
3324 wlvif->ap.recorded_keys[i] = ap_key;
3325 return 0;
3326 }
3327
wl1271_free_ap_keys(struct wl1271 * wl,struct wl12xx_vif * wlvif)3328 static void wl1271_free_ap_keys(struct wl1271 *wl, struct wl12xx_vif *wlvif)
3329 {
3330 int i;
3331
3332 for (i = 0; i < MAX_NUM_KEYS; i++) {
3333 kfree(wlvif->ap.recorded_keys[i]);
3334 wlvif->ap.recorded_keys[i] = NULL;
3335 }
3336 }
3337
wl1271_ap_init_hwenc(struct wl1271 * wl,struct wl12xx_vif * wlvif)3338 static int wl1271_ap_init_hwenc(struct wl1271 *wl, struct wl12xx_vif *wlvif)
3339 {
3340 int i, ret = 0;
3341 struct wl1271_ap_key *key;
3342 bool wep_key_added = false;
3343
3344 for (i = 0; i < MAX_NUM_KEYS; i++) {
3345 u8 hlid;
3346 if (wlvif->ap.recorded_keys[i] == NULL)
3347 break;
3348
3349 key = wlvif->ap.recorded_keys[i];
3350 hlid = key->hlid;
3351 if (hlid == WL12XX_INVALID_LINK_ID)
3352 hlid = wlvif->ap.bcast_hlid;
3353
3354 ret = wl1271_cmd_set_ap_key(wl, wlvif, KEY_ADD_OR_REPLACE,
3355 key->id, key->key_type,
3356 key->key_size, key->key,
3357 hlid, key->tx_seq_32,
3358 key->tx_seq_16);
3359 if (ret < 0)
3360 goto out;
3361
3362 if (key->key_type == KEY_WEP)
3363 wep_key_added = true;
3364 }
3365
3366 if (wep_key_added) {
3367 ret = wl12xx_cmd_set_default_wep_key(wl, wlvif->default_key,
3368 wlvif->ap.bcast_hlid);
3369 if (ret < 0)
3370 goto out;
3371 }
3372
3373 out:
3374 wl1271_free_ap_keys(wl, wlvif);
3375 return ret;
3376 }
3377
wl1271_set_key(struct wl1271 * wl,struct wl12xx_vif * wlvif,u16 action,u8 id,u8 key_type,u8 key_size,const u8 * key,u32 tx_seq_32,u16 tx_seq_16,struct ieee80211_sta * sta)3378 static int wl1271_set_key(struct wl1271 *wl, struct wl12xx_vif *wlvif,
3379 u16 action, u8 id, u8 key_type,
3380 u8 key_size, const u8 *key, u32 tx_seq_32,
3381 u16 tx_seq_16, struct ieee80211_sta *sta)
3382 {
3383 int ret;
3384 bool is_ap = (wlvif->bss_type == BSS_TYPE_AP_BSS);
3385
3386 if (is_ap) {
3387 struct wl1271_station *wl_sta;
3388 u8 hlid;
3389
3390 if (sta) {
3391 wl_sta = (struct wl1271_station *)sta->drv_priv;
3392 hlid = wl_sta->hlid;
3393 } else {
3394 hlid = wlvif->ap.bcast_hlid;
3395 }
3396
3397 if (!test_bit(WLVIF_FLAG_AP_STARTED, &wlvif->flags)) {
3398 /*
3399 * We do not support removing keys after AP shutdown.
3400 * Pretend we do to make mac80211 happy.
3401 */
3402 if (action != KEY_ADD_OR_REPLACE)
3403 return 0;
3404
3405 ret = wl1271_record_ap_key(wl, wlvif, id,
3406 key_type, key_size,
3407 key, hlid, tx_seq_32,
3408 tx_seq_16);
3409 } else {
3410 ret = wl1271_cmd_set_ap_key(wl, wlvif, action,
3411 id, key_type, key_size,
3412 key, hlid, tx_seq_32,
3413 tx_seq_16);
3414 }
3415
3416 if (ret < 0)
3417 return ret;
3418 } else {
3419 const u8 *addr;
3420 static const u8 bcast_addr[ETH_ALEN] = {
3421 0xff, 0xff, 0xff, 0xff, 0xff, 0xff
3422 };
3423
3424 addr = sta ? sta->addr : bcast_addr;
3425
3426 if (is_zero_ether_addr(addr)) {
3427 /* We dont support TX only encryption */
3428 return -EOPNOTSUPP;
3429 }
3430
3431 /* The wl1271 does not allow to remove unicast keys - they
3432 will be cleared automatically on next CMD_JOIN. Ignore the
3433 request silently, as we dont want the mac80211 to emit
3434 an error message. */
3435 if (action == KEY_REMOVE && !is_broadcast_ether_addr(addr))
3436 return 0;
3437
3438 /* don't remove key if hlid was already deleted */
3439 if (action == KEY_REMOVE &&
3440 wlvif->sta.hlid == WL12XX_INVALID_LINK_ID)
3441 return 0;
3442
3443 ret = wl1271_cmd_set_sta_key(wl, wlvif, action,
3444 id, key_type, key_size,
3445 key, addr, tx_seq_32,
3446 tx_seq_16);
3447 if (ret < 0)
3448 return ret;
3449
3450 }
3451
3452 return 0;
3453 }
3454
wlcore_op_set_key(struct ieee80211_hw * hw,enum set_key_cmd cmd,struct ieee80211_vif * vif,struct ieee80211_sta * sta,struct ieee80211_key_conf * key_conf)3455 static int wlcore_op_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd,
3456 struct ieee80211_vif *vif,
3457 struct ieee80211_sta *sta,
3458 struct ieee80211_key_conf *key_conf)
3459 {
3460 struct wl1271 *wl = hw->priv;
3461 int ret;
3462 bool might_change_spare =
3463 key_conf->cipher == WL1271_CIPHER_SUITE_GEM ||
3464 key_conf->cipher == WLAN_CIPHER_SUITE_TKIP;
3465
3466 if (might_change_spare) {
3467 /*
3468 * stop the queues and flush to ensure the next packets are
3469 * in sync with FW spare block accounting
3470 */
3471 wlcore_stop_queues(wl, WLCORE_QUEUE_STOP_REASON_SPARE_BLK);
3472 wl1271_tx_flush(wl);
3473 }
3474
3475 mutex_lock(&wl->mutex);
3476
3477 if (unlikely(wl->state != WLCORE_STATE_ON)) {
3478 ret = -EAGAIN;
3479 goto out_wake_queues;
3480 }
3481
3482 ret = pm_runtime_get_sync(wl->dev);
3483 if (ret < 0) {
3484 pm_runtime_put_noidle(wl->dev);
3485 goto out_wake_queues;
3486 }
3487
3488 ret = wlcore_hw_set_key(wl, cmd, vif, sta, key_conf);
3489
3490 pm_runtime_mark_last_busy(wl->dev);
3491 pm_runtime_put_autosuspend(wl->dev);
3492
3493 out_wake_queues:
3494 if (might_change_spare)
3495 wlcore_wake_queues(wl, WLCORE_QUEUE_STOP_REASON_SPARE_BLK);
3496
3497 mutex_unlock(&wl->mutex);
3498
3499 return ret;
3500 }
3501
wlcore_set_key(struct wl1271 * wl,enum set_key_cmd cmd,struct ieee80211_vif * vif,struct ieee80211_sta * sta,struct ieee80211_key_conf * key_conf)3502 int wlcore_set_key(struct wl1271 *wl, enum set_key_cmd cmd,
3503 struct ieee80211_vif *vif,
3504 struct ieee80211_sta *sta,
3505 struct ieee80211_key_conf *key_conf)
3506 {
3507 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
3508 int ret;
3509 u32 tx_seq_32 = 0;
3510 u16 tx_seq_16 = 0;
3511 u8 key_type;
3512 u8 hlid;
3513
3514 wl1271_debug(DEBUG_MAC80211, "mac80211 set key");
3515
3516 wl1271_debug(DEBUG_CRYPT, "CMD: 0x%x sta: %p", cmd, sta);
3517 wl1271_debug(DEBUG_CRYPT, "Key: algo:0x%x, id:%d, len:%d flags 0x%x",
3518 key_conf->cipher, key_conf->keyidx,
3519 key_conf->keylen, key_conf->flags);
3520 wl1271_dump(DEBUG_CRYPT, "KEY: ", key_conf->key, key_conf->keylen);
3521
3522 if (wlvif->bss_type == BSS_TYPE_AP_BSS)
3523 if (sta) {
3524 struct wl1271_station *wl_sta = (void *)sta->drv_priv;
3525 hlid = wl_sta->hlid;
3526 } else {
3527 hlid = wlvif->ap.bcast_hlid;
3528 }
3529 else
3530 hlid = wlvif->sta.hlid;
3531
3532 if (hlid != WL12XX_INVALID_LINK_ID) {
3533 u64 tx_seq = wl->links[hlid].total_freed_pkts;
3534 tx_seq_32 = WL1271_TX_SECURITY_HI32(tx_seq);
3535 tx_seq_16 = WL1271_TX_SECURITY_LO16(tx_seq);
3536 }
3537
3538 switch (key_conf->cipher) {
3539 case WLAN_CIPHER_SUITE_WEP40:
3540 case WLAN_CIPHER_SUITE_WEP104:
3541 key_type = KEY_WEP;
3542
3543 key_conf->hw_key_idx = key_conf->keyidx;
3544 break;
3545 case WLAN_CIPHER_SUITE_TKIP:
3546 key_type = KEY_TKIP;
3547 key_conf->hw_key_idx = key_conf->keyidx;
3548 break;
3549 case WLAN_CIPHER_SUITE_CCMP:
3550 key_type = KEY_AES;
3551 key_conf->flags |= IEEE80211_KEY_FLAG_PUT_IV_SPACE;
3552 break;
3553 case WL1271_CIPHER_SUITE_GEM:
3554 key_type = KEY_GEM;
3555 break;
3556 default:
3557 wl1271_error("Unknown key algo 0x%x", key_conf->cipher);
3558
3559 return -EOPNOTSUPP;
3560 }
3561
3562 switch (cmd) {
3563 case SET_KEY:
3564 ret = wl1271_set_key(wl, wlvif, KEY_ADD_OR_REPLACE,
3565 key_conf->keyidx, key_type,
3566 key_conf->keylen, key_conf->key,
3567 tx_seq_32, tx_seq_16, sta);
3568 if (ret < 0) {
3569 wl1271_error("Could not add or replace key");
3570 return ret;
3571 }
3572
3573 /*
3574 * reconfiguring arp response if the unicast (or common)
3575 * encryption key type was changed
3576 */
3577 if (wlvif->bss_type == BSS_TYPE_STA_BSS &&
3578 (sta || key_type == KEY_WEP) &&
3579 wlvif->encryption_type != key_type) {
3580 wlvif->encryption_type = key_type;
3581 ret = wl1271_cmd_build_arp_rsp(wl, wlvif);
3582 if (ret < 0) {
3583 wl1271_warning("build arp rsp failed: %d", ret);
3584 return ret;
3585 }
3586 }
3587 break;
3588
3589 case DISABLE_KEY:
3590 ret = wl1271_set_key(wl, wlvif, KEY_REMOVE,
3591 key_conf->keyidx, key_type,
3592 key_conf->keylen, key_conf->key,
3593 0, 0, sta);
3594 if (ret < 0) {
3595 wl1271_error("Could not remove key");
3596 return ret;
3597 }
3598 break;
3599
3600 default:
3601 wl1271_error("Unsupported key cmd 0x%x", cmd);
3602 return -EOPNOTSUPP;
3603 }
3604
3605 return ret;
3606 }
3607 EXPORT_SYMBOL_GPL(wlcore_set_key);
3608
wl1271_op_set_default_key_idx(struct ieee80211_hw * hw,struct ieee80211_vif * vif,int key_idx)3609 static void wl1271_op_set_default_key_idx(struct ieee80211_hw *hw,
3610 struct ieee80211_vif *vif,
3611 int key_idx)
3612 {
3613 struct wl1271 *wl = hw->priv;
3614 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
3615 int ret;
3616
3617 wl1271_debug(DEBUG_MAC80211, "mac80211 set default key idx %d",
3618 key_idx);
3619
3620 /* we don't handle unsetting of default key */
3621 if (key_idx == -1)
3622 return;
3623
3624 mutex_lock(&wl->mutex);
3625
3626 if (unlikely(wl->state != WLCORE_STATE_ON)) {
3627 ret = -EAGAIN;
3628 goto out_unlock;
3629 }
3630
3631 ret = pm_runtime_get_sync(wl->dev);
3632 if (ret < 0) {
3633 pm_runtime_put_noidle(wl->dev);
3634 goto out_unlock;
3635 }
3636
3637 wlvif->default_key = key_idx;
3638
3639 /* the default WEP key needs to be configured at least once */
3640 if (wlvif->encryption_type == KEY_WEP) {
3641 ret = wl12xx_cmd_set_default_wep_key(wl,
3642 key_idx,
3643 wlvif->sta.hlid);
3644 if (ret < 0)
3645 goto out_sleep;
3646 }
3647
3648 out_sleep:
3649 pm_runtime_mark_last_busy(wl->dev);
3650 pm_runtime_put_autosuspend(wl->dev);
3651
3652 out_unlock:
3653 mutex_unlock(&wl->mutex);
3654 }
3655
wlcore_regdomain_config(struct wl1271 * wl)3656 void wlcore_regdomain_config(struct wl1271 *wl)
3657 {
3658 int ret;
3659
3660 if (!(wl->quirks & WLCORE_QUIRK_REGDOMAIN_CONF))
3661 return;
3662
3663 mutex_lock(&wl->mutex);
3664
3665 if (unlikely(wl->state != WLCORE_STATE_ON))
3666 goto out;
3667
3668 ret = pm_runtime_get_sync(wl->dev);
3669 if (ret < 0)
3670 goto out;
3671
3672 ret = wlcore_cmd_regdomain_config_locked(wl);
3673 if (ret < 0) {
3674 wl12xx_queue_recovery_work(wl);
3675 goto out;
3676 }
3677
3678 pm_runtime_mark_last_busy(wl->dev);
3679 pm_runtime_put_autosuspend(wl->dev);
3680 out:
3681 mutex_unlock(&wl->mutex);
3682 }
3683
wl1271_op_hw_scan(struct ieee80211_hw * hw,struct ieee80211_vif * vif,struct ieee80211_scan_request * hw_req)3684 static int wl1271_op_hw_scan(struct ieee80211_hw *hw,
3685 struct ieee80211_vif *vif,
3686 struct ieee80211_scan_request *hw_req)
3687 {
3688 struct cfg80211_scan_request *req = &hw_req->req;
3689 struct wl1271 *wl = hw->priv;
3690 int ret;
3691 u8 *ssid = NULL;
3692 size_t len = 0;
3693
3694 wl1271_debug(DEBUG_MAC80211, "mac80211 hw scan");
3695
3696 if (req->n_ssids) {
3697 ssid = req->ssids[0].ssid;
3698 len = req->ssids[0].ssid_len;
3699 }
3700
3701 mutex_lock(&wl->mutex);
3702
3703 if (unlikely(wl->state != WLCORE_STATE_ON)) {
3704 /*
3705 * We cannot return -EBUSY here because cfg80211 will expect
3706 * a call to ieee80211_scan_completed if we do - in this case
3707 * there won't be any call.
3708 */
3709 ret = -EAGAIN;
3710 goto out;
3711 }
3712
3713 ret = pm_runtime_get_sync(wl->dev);
3714 if (ret < 0) {
3715 pm_runtime_put_noidle(wl->dev);
3716 goto out;
3717 }
3718
3719 /* fail if there is any role in ROC */
3720 if (find_first_bit(wl->roc_map, WL12XX_MAX_ROLES) < WL12XX_MAX_ROLES) {
3721 /* don't allow scanning right now */
3722 ret = -EBUSY;
3723 goto out_sleep;
3724 }
3725
3726 ret = wlcore_scan(hw->priv, vif, ssid, len, req);
3727 out_sleep:
3728 pm_runtime_mark_last_busy(wl->dev);
3729 pm_runtime_put_autosuspend(wl->dev);
3730 out:
3731 mutex_unlock(&wl->mutex);
3732
3733 return ret;
3734 }
3735
wl1271_op_cancel_hw_scan(struct ieee80211_hw * hw,struct ieee80211_vif * vif)3736 static void wl1271_op_cancel_hw_scan(struct ieee80211_hw *hw,
3737 struct ieee80211_vif *vif)
3738 {
3739 struct wl1271 *wl = hw->priv;
3740 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
3741 struct cfg80211_scan_info info = {
3742 .aborted = true,
3743 };
3744 int ret;
3745
3746 wl1271_debug(DEBUG_MAC80211, "mac80211 cancel hw scan");
3747
3748 mutex_lock(&wl->mutex);
3749
3750 if (unlikely(wl->state != WLCORE_STATE_ON))
3751 goto out;
3752
3753 if (wl->scan.state == WL1271_SCAN_STATE_IDLE)
3754 goto out;
3755
3756 ret = pm_runtime_get_sync(wl->dev);
3757 if (ret < 0) {
3758 pm_runtime_put_noidle(wl->dev);
3759 goto out;
3760 }
3761
3762 if (wl->scan.state != WL1271_SCAN_STATE_DONE) {
3763 ret = wl->ops->scan_stop(wl, wlvif);
3764 if (ret < 0)
3765 goto out_sleep;
3766 }
3767
3768 /*
3769 * Rearm the tx watchdog just before idling scan. This
3770 * prevents just-finished scans from triggering the watchdog
3771 */
3772 wl12xx_rearm_tx_watchdog_locked(wl);
3773
3774 wl->scan.state = WL1271_SCAN_STATE_IDLE;
3775 memset(wl->scan.scanned_ch, 0, sizeof(wl->scan.scanned_ch));
3776 wl->scan_wlvif = NULL;
3777 wl->scan.req = NULL;
3778 ieee80211_scan_completed(wl->hw, &info);
3779
3780 out_sleep:
3781 pm_runtime_mark_last_busy(wl->dev);
3782 pm_runtime_put_autosuspend(wl->dev);
3783 out:
3784 mutex_unlock(&wl->mutex);
3785
3786 cancel_delayed_work_sync(&wl->scan_complete_work);
3787 }
3788
wl1271_op_sched_scan_start(struct ieee80211_hw * hw,struct ieee80211_vif * vif,struct cfg80211_sched_scan_request * req,struct ieee80211_scan_ies * ies)3789 static int wl1271_op_sched_scan_start(struct ieee80211_hw *hw,
3790 struct ieee80211_vif *vif,
3791 struct cfg80211_sched_scan_request *req,
3792 struct ieee80211_scan_ies *ies)
3793 {
3794 struct wl1271 *wl = hw->priv;
3795 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
3796 int ret;
3797
3798 wl1271_debug(DEBUG_MAC80211, "wl1271_op_sched_scan_start");
3799
3800 mutex_lock(&wl->mutex);
3801
3802 if (unlikely(wl->state != WLCORE_STATE_ON)) {
3803 ret = -EAGAIN;
3804 goto out;
3805 }
3806
3807 ret = pm_runtime_get_sync(wl->dev);
3808 if (ret < 0) {
3809 pm_runtime_put_noidle(wl->dev);
3810 goto out;
3811 }
3812
3813 ret = wl->ops->sched_scan_start(wl, wlvif, req, ies);
3814 if (ret < 0)
3815 goto out_sleep;
3816
3817 wl->sched_vif = wlvif;
3818
3819 out_sleep:
3820 pm_runtime_mark_last_busy(wl->dev);
3821 pm_runtime_put_autosuspend(wl->dev);
3822 out:
3823 mutex_unlock(&wl->mutex);
3824 return ret;
3825 }
3826
wl1271_op_sched_scan_stop(struct ieee80211_hw * hw,struct ieee80211_vif * vif)3827 static int wl1271_op_sched_scan_stop(struct ieee80211_hw *hw,
3828 struct ieee80211_vif *vif)
3829 {
3830 struct wl1271 *wl = hw->priv;
3831 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
3832 int ret;
3833
3834 wl1271_debug(DEBUG_MAC80211, "wl1271_op_sched_scan_stop");
3835
3836 mutex_lock(&wl->mutex);
3837
3838 if (unlikely(wl->state != WLCORE_STATE_ON))
3839 goto out;
3840
3841 ret = pm_runtime_get_sync(wl->dev);
3842 if (ret < 0) {
3843 pm_runtime_put_noidle(wl->dev);
3844 goto out;
3845 }
3846
3847 wl->ops->sched_scan_stop(wl, wlvif);
3848
3849 pm_runtime_mark_last_busy(wl->dev);
3850 pm_runtime_put_autosuspend(wl->dev);
3851 out:
3852 mutex_unlock(&wl->mutex);
3853
3854 return 0;
3855 }
3856
wl1271_op_set_frag_threshold(struct ieee80211_hw * hw,u32 value)3857 static int wl1271_op_set_frag_threshold(struct ieee80211_hw *hw, u32 value)
3858 {
3859 struct wl1271 *wl = hw->priv;
3860 int ret = 0;
3861
3862 mutex_lock(&wl->mutex);
3863
3864 if (unlikely(wl->state != WLCORE_STATE_ON)) {
3865 ret = -EAGAIN;
3866 goto out;
3867 }
3868
3869 ret = pm_runtime_get_sync(wl->dev);
3870 if (ret < 0) {
3871 pm_runtime_put_noidle(wl->dev);
3872 goto out;
3873 }
3874
3875 ret = wl1271_acx_frag_threshold(wl, value);
3876 if (ret < 0)
3877 wl1271_warning("wl1271_op_set_frag_threshold failed: %d", ret);
3878
3879 pm_runtime_mark_last_busy(wl->dev);
3880 pm_runtime_put_autosuspend(wl->dev);
3881
3882 out:
3883 mutex_unlock(&wl->mutex);
3884
3885 return ret;
3886 }
3887
wl1271_op_set_rts_threshold(struct ieee80211_hw * hw,u32 value)3888 static int wl1271_op_set_rts_threshold(struct ieee80211_hw *hw, u32 value)
3889 {
3890 struct wl1271 *wl = hw->priv;
3891 struct wl12xx_vif *wlvif;
3892 int ret = 0;
3893
3894 mutex_lock(&wl->mutex);
3895
3896 if (unlikely(wl->state != WLCORE_STATE_ON)) {
3897 ret = -EAGAIN;
3898 goto out;
3899 }
3900
3901 ret = pm_runtime_get_sync(wl->dev);
3902 if (ret < 0) {
3903 pm_runtime_put_noidle(wl->dev);
3904 goto out;
3905 }
3906
3907 wl12xx_for_each_wlvif(wl, wlvif) {
3908 ret = wl1271_acx_rts_threshold(wl, wlvif, value);
3909 if (ret < 0)
3910 wl1271_warning("set rts threshold failed: %d", ret);
3911 }
3912 pm_runtime_mark_last_busy(wl->dev);
3913 pm_runtime_put_autosuspend(wl->dev);
3914
3915 out:
3916 mutex_unlock(&wl->mutex);
3917
3918 return ret;
3919 }
3920
wl12xx_remove_ie(struct sk_buff * skb,u8 eid,int ieoffset)3921 static void wl12xx_remove_ie(struct sk_buff *skb, u8 eid, int ieoffset)
3922 {
3923 int len;
3924 const u8 *next, *end = skb->data + skb->len;
3925 u8 *ie = (u8 *)cfg80211_find_ie(eid, skb->data + ieoffset,
3926 skb->len - ieoffset);
3927 if (!ie)
3928 return;
3929 len = ie[1] + 2;
3930 next = ie + len;
3931 memmove(ie, next, end - next);
3932 skb_trim(skb, skb->len - len);
3933 }
3934
wl12xx_remove_vendor_ie(struct sk_buff * skb,unsigned int oui,u8 oui_type,int ieoffset)3935 static void wl12xx_remove_vendor_ie(struct sk_buff *skb,
3936 unsigned int oui, u8 oui_type,
3937 int ieoffset)
3938 {
3939 int len;
3940 const u8 *next, *end = skb->data + skb->len;
3941 u8 *ie = (u8 *)cfg80211_find_vendor_ie(oui, oui_type,
3942 skb->data + ieoffset,
3943 skb->len - ieoffset);
3944 if (!ie)
3945 return;
3946 len = ie[1] + 2;
3947 next = ie + len;
3948 memmove(ie, next, end - next);
3949 skb_trim(skb, skb->len - len);
3950 }
3951
wl1271_ap_set_probe_resp_tmpl(struct wl1271 * wl,u32 rates,struct ieee80211_vif * vif)3952 static int wl1271_ap_set_probe_resp_tmpl(struct wl1271 *wl, u32 rates,
3953 struct ieee80211_vif *vif)
3954 {
3955 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
3956 struct sk_buff *skb;
3957 int ret;
3958
3959 skb = ieee80211_proberesp_get(wl->hw, vif);
3960 if (!skb)
3961 return -EOPNOTSUPP;
3962
3963 ret = wl1271_cmd_template_set(wl, wlvif->role_id,
3964 CMD_TEMPL_AP_PROBE_RESPONSE,
3965 skb->data,
3966 skb->len, 0,
3967 rates);
3968 dev_kfree_skb(skb);
3969
3970 if (ret < 0)
3971 goto out;
3972
3973 wl1271_debug(DEBUG_AP, "probe response updated");
3974 set_bit(WLVIF_FLAG_AP_PROBE_RESP_SET, &wlvif->flags);
3975
3976 out:
3977 return ret;
3978 }
3979
wl1271_ap_set_probe_resp_tmpl_legacy(struct wl1271 * wl,struct ieee80211_vif * vif,u8 * probe_rsp_data,size_t probe_rsp_len,u32 rates)3980 static int wl1271_ap_set_probe_resp_tmpl_legacy(struct wl1271 *wl,
3981 struct ieee80211_vif *vif,
3982 u8 *probe_rsp_data,
3983 size_t probe_rsp_len,
3984 u32 rates)
3985 {
3986 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
3987 struct ieee80211_bss_conf *bss_conf = &vif->bss_conf;
3988 u8 probe_rsp_templ[WL1271_CMD_TEMPL_MAX_SIZE];
3989 int ssid_ie_offset, ie_offset, templ_len;
3990 const u8 *ptr;
3991
3992 /* no need to change probe response if the SSID is set correctly */
3993 if (wlvif->ssid_len > 0)
3994 return wl1271_cmd_template_set(wl, wlvif->role_id,
3995 CMD_TEMPL_AP_PROBE_RESPONSE,
3996 probe_rsp_data,
3997 probe_rsp_len, 0,
3998 rates);
3999
4000 if (probe_rsp_len + bss_conf->ssid_len > WL1271_CMD_TEMPL_MAX_SIZE) {
4001 wl1271_error("probe_rsp template too big");
4002 return -EINVAL;
4003 }
4004
4005 /* start searching from IE offset */
4006 ie_offset = offsetof(struct ieee80211_mgmt, u.probe_resp.variable);
4007
4008 ptr = cfg80211_find_ie(WLAN_EID_SSID, probe_rsp_data + ie_offset,
4009 probe_rsp_len - ie_offset);
4010 if (!ptr) {
4011 wl1271_error("No SSID in beacon!");
4012 return -EINVAL;
4013 }
4014
4015 ssid_ie_offset = ptr - probe_rsp_data;
4016 ptr += (ptr[1] + 2);
4017
4018 memcpy(probe_rsp_templ, probe_rsp_data, ssid_ie_offset);
4019
4020 /* insert SSID from bss_conf */
4021 probe_rsp_templ[ssid_ie_offset] = WLAN_EID_SSID;
4022 probe_rsp_templ[ssid_ie_offset + 1] = bss_conf->ssid_len;
4023 memcpy(probe_rsp_templ + ssid_ie_offset + 2,
4024 bss_conf->ssid, bss_conf->ssid_len);
4025 templ_len = ssid_ie_offset + 2 + bss_conf->ssid_len;
4026
4027 memcpy(probe_rsp_templ + ssid_ie_offset + 2 + bss_conf->ssid_len,
4028 ptr, probe_rsp_len - (ptr - probe_rsp_data));
4029 templ_len += probe_rsp_len - (ptr - probe_rsp_data);
4030
4031 return wl1271_cmd_template_set(wl, wlvif->role_id,
4032 CMD_TEMPL_AP_PROBE_RESPONSE,
4033 probe_rsp_templ,
4034 templ_len, 0,
4035 rates);
4036 }
4037
wl1271_bss_erp_info_changed(struct wl1271 * wl,struct ieee80211_vif * vif,struct ieee80211_bss_conf * bss_conf,u32 changed)4038 static int wl1271_bss_erp_info_changed(struct wl1271 *wl,
4039 struct ieee80211_vif *vif,
4040 struct ieee80211_bss_conf *bss_conf,
4041 u32 changed)
4042 {
4043 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
4044 int ret = 0;
4045
4046 if (changed & BSS_CHANGED_ERP_SLOT) {
4047 if (bss_conf->use_short_slot)
4048 ret = wl1271_acx_slot(wl, wlvif, SLOT_TIME_SHORT);
4049 else
4050 ret = wl1271_acx_slot(wl, wlvif, SLOT_TIME_LONG);
4051 if (ret < 0) {
4052 wl1271_warning("Set slot time failed %d", ret);
4053 goto out;
4054 }
4055 }
4056
4057 if (changed & BSS_CHANGED_ERP_PREAMBLE) {
4058 if (bss_conf->use_short_preamble)
4059 wl1271_acx_set_preamble(wl, wlvif, ACX_PREAMBLE_SHORT);
4060 else
4061 wl1271_acx_set_preamble(wl, wlvif, ACX_PREAMBLE_LONG);
4062 }
4063
4064 if (changed & BSS_CHANGED_ERP_CTS_PROT) {
4065 if (bss_conf->use_cts_prot)
4066 ret = wl1271_acx_cts_protect(wl, wlvif,
4067 CTSPROTECT_ENABLE);
4068 else
4069 ret = wl1271_acx_cts_protect(wl, wlvif,
4070 CTSPROTECT_DISABLE);
4071 if (ret < 0) {
4072 wl1271_warning("Set ctsprotect failed %d", ret);
4073 goto out;
4074 }
4075 }
4076
4077 out:
4078 return ret;
4079 }
4080
wlcore_set_beacon_template(struct wl1271 * wl,struct ieee80211_vif * vif,bool is_ap)4081 static int wlcore_set_beacon_template(struct wl1271 *wl,
4082 struct ieee80211_vif *vif,
4083 bool is_ap)
4084 {
4085 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
4086 struct ieee80211_hdr *hdr;
4087 u32 min_rate;
4088 int ret;
4089 int ieoffset = offsetof(struct ieee80211_mgmt, u.beacon.variable);
4090 struct sk_buff *beacon = ieee80211_beacon_get(wl->hw, vif);
4091 u16 tmpl_id;
4092
4093 if (!beacon) {
4094 ret = -EINVAL;
4095 goto out;
4096 }
4097
4098 wl1271_debug(DEBUG_MASTER, "beacon updated");
4099
4100 ret = wl1271_ssid_set(wlvif, beacon, ieoffset);
4101 if (ret < 0) {
4102 dev_kfree_skb(beacon);
4103 goto out;
4104 }
4105 min_rate = wl1271_tx_min_rate_get(wl, wlvif->basic_rate_set);
4106 tmpl_id = is_ap ? CMD_TEMPL_AP_BEACON :
4107 CMD_TEMPL_BEACON;
4108 ret = wl1271_cmd_template_set(wl, wlvif->role_id, tmpl_id,
4109 beacon->data,
4110 beacon->len, 0,
4111 min_rate);
4112 if (ret < 0) {
4113 dev_kfree_skb(beacon);
4114 goto out;
4115 }
4116
4117 wlvif->wmm_enabled =
4118 cfg80211_find_vendor_ie(WLAN_OUI_MICROSOFT,
4119 WLAN_OUI_TYPE_MICROSOFT_WMM,
4120 beacon->data + ieoffset,
4121 beacon->len - ieoffset);
4122
4123 /*
4124 * In case we already have a probe-resp beacon set explicitly
4125 * by usermode, don't use the beacon data.
4126 */
4127 if (test_bit(WLVIF_FLAG_AP_PROBE_RESP_SET, &wlvif->flags))
4128 goto end_bcn;
4129
4130 /* remove TIM ie from probe response */
4131 wl12xx_remove_ie(beacon, WLAN_EID_TIM, ieoffset);
4132
4133 /*
4134 * remove p2p ie from probe response.
4135 * the fw reponds to probe requests that don't include
4136 * the p2p ie. probe requests with p2p ie will be passed,
4137 * and will be responded by the supplicant (the spec
4138 * forbids including the p2p ie when responding to probe
4139 * requests that didn't include it).
4140 */
4141 wl12xx_remove_vendor_ie(beacon, WLAN_OUI_WFA,
4142 WLAN_OUI_TYPE_WFA_P2P, ieoffset);
4143
4144 hdr = (struct ieee80211_hdr *) beacon->data;
4145 hdr->frame_control = cpu_to_le16(IEEE80211_FTYPE_MGMT |
4146 IEEE80211_STYPE_PROBE_RESP);
4147 if (is_ap)
4148 ret = wl1271_ap_set_probe_resp_tmpl_legacy(wl, vif,
4149 beacon->data,
4150 beacon->len,
4151 min_rate);
4152 else
4153 ret = wl1271_cmd_template_set(wl, wlvif->role_id,
4154 CMD_TEMPL_PROBE_RESPONSE,
4155 beacon->data,
4156 beacon->len, 0,
4157 min_rate);
4158 end_bcn:
4159 dev_kfree_skb(beacon);
4160 if (ret < 0)
4161 goto out;
4162
4163 out:
4164 return ret;
4165 }
4166
wl1271_bss_beacon_info_changed(struct wl1271 * wl,struct ieee80211_vif * vif,struct ieee80211_bss_conf * bss_conf,u32 changed)4167 static int wl1271_bss_beacon_info_changed(struct wl1271 *wl,
4168 struct ieee80211_vif *vif,
4169 struct ieee80211_bss_conf *bss_conf,
4170 u32 changed)
4171 {
4172 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
4173 bool is_ap = (wlvif->bss_type == BSS_TYPE_AP_BSS);
4174 int ret = 0;
4175
4176 if (changed & BSS_CHANGED_BEACON_INT) {
4177 wl1271_debug(DEBUG_MASTER, "beacon interval updated: %d",
4178 bss_conf->beacon_int);
4179
4180 wlvif->beacon_int = bss_conf->beacon_int;
4181 }
4182
4183 if ((changed & BSS_CHANGED_AP_PROBE_RESP) && is_ap) {
4184 u32 rate = wl1271_tx_min_rate_get(wl, wlvif->basic_rate_set);
4185
4186 wl1271_ap_set_probe_resp_tmpl(wl, rate, vif);
4187 }
4188
4189 if (changed & BSS_CHANGED_BEACON) {
4190 ret = wlcore_set_beacon_template(wl, vif, is_ap);
4191 if (ret < 0)
4192 goto out;
4193
4194 if (test_and_clear_bit(WLVIF_FLAG_BEACON_DISABLED,
4195 &wlvif->flags)) {
4196 ret = wlcore_hw_dfs_master_restart(wl, wlvif);
4197 if (ret < 0)
4198 goto out;
4199 }
4200 }
4201 out:
4202 if (ret != 0)
4203 wl1271_error("beacon info change failed: %d", ret);
4204 return ret;
4205 }
4206
4207 /* AP mode changes */
wl1271_bss_info_changed_ap(struct wl1271 * wl,struct ieee80211_vif * vif,struct ieee80211_bss_conf * bss_conf,u32 changed)4208 static void wl1271_bss_info_changed_ap(struct wl1271 *wl,
4209 struct ieee80211_vif *vif,
4210 struct ieee80211_bss_conf *bss_conf,
4211 u32 changed)
4212 {
4213 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
4214 int ret = 0;
4215
4216 if (changed & BSS_CHANGED_BASIC_RATES) {
4217 u32 rates = bss_conf->basic_rates;
4218
4219 wlvif->basic_rate_set = wl1271_tx_enabled_rates_get(wl, rates,
4220 wlvif->band);
4221 wlvif->basic_rate = wl1271_tx_min_rate_get(wl,
4222 wlvif->basic_rate_set);
4223
4224 ret = wl1271_init_ap_rates(wl, wlvif);
4225 if (ret < 0) {
4226 wl1271_error("AP rate policy change failed %d", ret);
4227 goto out;
4228 }
4229
4230 ret = wl1271_ap_init_templates(wl, vif);
4231 if (ret < 0)
4232 goto out;
4233
4234 /* No need to set probe resp template for mesh */
4235 if (!ieee80211_vif_is_mesh(vif)) {
4236 ret = wl1271_ap_set_probe_resp_tmpl(wl,
4237 wlvif->basic_rate,
4238 vif);
4239 if (ret < 0)
4240 goto out;
4241 }
4242
4243 ret = wlcore_set_beacon_template(wl, vif, true);
4244 if (ret < 0)
4245 goto out;
4246 }
4247
4248 ret = wl1271_bss_beacon_info_changed(wl, vif, bss_conf, changed);
4249 if (ret < 0)
4250 goto out;
4251
4252 if (changed & BSS_CHANGED_BEACON_ENABLED) {
4253 if (bss_conf->enable_beacon) {
4254 if (!test_bit(WLVIF_FLAG_AP_STARTED, &wlvif->flags)) {
4255 ret = wl12xx_cmd_role_start_ap(wl, wlvif);
4256 if (ret < 0)
4257 goto out;
4258
4259 ret = wl1271_ap_init_hwenc(wl, wlvif);
4260 if (ret < 0)
4261 goto out;
4262
4263 set_bit(WLVIF_FLAG_AP_STARTED, &wlvif->flags);
4264 wl1271_debug(DEBUG_AP, "started AP");
4265 }
4266 } else {
4267 if (test_bit(WLVIF_FLAG_AP_STARTED, &wlvif->flags)) {
4268 /*
4269 * AP might be in ROC in case we have just
4270 * sent auth reply. handle it.
4271 */
4272 if (test_bit(wlvif->role_id, wl->roc_map))
4273 wl12xx_croc(wl, wlvif->role_id);
4274
4275 ret = wl12xx_cmd_role_stop_ap(wl, wlvif);
4276 if (ret < 0)
4277 goto out;
4278
4279 clear_bit(WLVIF_FLAG_AP_STARTED, &wlvif->flags);
4280 clear_bit(WLVIF_FLAG_AP_PROBE_RESP_SET,
4281 &wlvif->flags);
4282 wl1271_debug(DEBUG_AP, "stopped AP");
4283 }
4284 }
4285 }
4286
4287 ret = wl1271_bss_erp_info_changed(wl, vif, bss_conf, changed);
4288 if (ret < 0)
4289 goto out;
4290
4291 /* Handle HT information change */
4292 if ((changed & BSS_CHANGED_HT) &&
4293 (bss_conf->chandef.width != NL80211_CHAN_WIDTH_20_NOHT)) {
4294 ret = wl1271_acx_set_ht_information(wl, wlvif,
4295 bss_conf->ht_operation_mode);
4296 if (ret < 0) {
4297 wl1271_warning("Set ht information failed %d", ret);
4298 goto out;
4299 }
4300 }
4301
4302 out:
4303 return;
4304 }
4305
wlcore_set_bssid(struct wl1271 * wl,struct wl12xx_vif * wlvif,struct ieee80211_bss_conf * bss_conf,u32 sta_rate_set)4306 static int wlcore_set_bssid(struct wl1271 *wl, struct wl12xx_vif *wlvif,
4307 struct ieee80211_bss_conf *bss_conf,
4308 u32 sta_rate_set)
4309 {
4310 u32 rates;
4311 int ret;
4312
4313 wl1271_debug(DEBUG_MAC80211,
4314 "changed_bssid: %pM, aid: %d, bcn_int: %d, brates: 0x%x sta_rate_set: 0x%x",
4315 bss_conf->bssid, bss_conf->aid,
4316 bss_conf->beacon_int,
4317 bss_conf->basic_rates, sta_rate_set);
4318
4319 wlvif->beacon_int = bss_conf->beacon_int;
4320 rates = bss_conf->basic_rates;
4321 wlvif->basic_rate_set =
4322 wl1271_tx_enabled_rates_get(wl, rates,
4323 wlvif->band);
4324 wlvif->basic_rate =
4325 wl1271_tx_min_rate_get(wl,
4326 wlvif->basic_rate_set);
4327
4328 if (sta_rate_set)
4329 wlvif->rate_set =
4330 wl1271_tx_enabled_rates_get(wl,
4331 sta_rate_set,
4332 wlvif->band);
4333
4334 /* we only support sched_scan while not connected */
4335 if (wl->sched_vif == wlvif)
4336 wl->ops->sched_scan_stop(wl, wlvif);
4337
4338 ret = wl1271_acx_sta_rate_policies(wl, wlvif);
4339 if (ret < 0)
4340 return ret;
4341
4342 ret = wl12xx_cmd_build_null_data(wl, wlvif);
4343 if (ret < 0)
4344 return ret;
4345
4346 ret = wl1271_build_qos_null_data(wl, wl12xx_wlvif_to_vif(wlvif));
4347 if (ret < 0)
4348 return ret;
4349
4350 wlcore_set_ssid(wl, wlvif);
4351
4352 set_bit(WLVIF_FLAG_IN_USE, &wlvif->flags);
4353
4354 return 0;
4355 }
4356
wlcore_clear_bssid(struct wl1271 * wl,struct wl12xx_vif * wlvif)4357 static int wlcore_clear_bssid(struct wl1271 *wl, struct wl12xx_vif *wlvif)
4358 {
4359 int ret;
4360
4361 /* revert back to minimum rates for the current band */
4362 wl1271_set_band_rate(wl, wlvif);
4363 wlvif->basic_rate = wl1271_tx_min_rate_get(wl, wlvif->basic_rate_set);
4364
4365 ret = wl1271_acx_sta_rate_policies(wl, wlvif);
4366 if (ret < 0)
4367 return ret;
4368
4369 if (wlvif->bss_type == BSS_TYPE_STA_BSS &&
4370 test_bit(WLVIF_FLAG_IN_USE, &wlvif->flags)) {
4371 ret = wl12xx_cmd_role_stop_sta(wl, wlvif);
4372 if (ret < 0)
4373 return ret;
4374 }
4375
4376 clear_bit(WLVIF_FLAG_IN_USE, &wlvif->flags);
4377 return 0;
4378 }
4379 /* STA/IBSS mode changes */
wl1271_bss_info_changed_sta(struct wl1271 * wl,struct ieee80211_vif * vif,struct ieee80211_bss_conf * bss_conf,u32 changed)4380 static void wl1271_bss_info_changed_sta(struct wl1271 *wl,
4381 struct ieee80211_vif *vif,
4382 struct ieee80211_bss_conf *bss_conf,
4383 u32 changed)
4384 {
4385 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
4386 bool do_join = false;
4387 bool is_ibss = (wlvif->bss_type == BSS_TYPE_IBSS);
4388 bool ibss_joined = false;
4389 u32 sta_rate_set = 0;
4390 int ret;
4391 struct ieee80211_sta *sta;
4392 bool sta_exists = false;
4393 struct ieee80211_sta_ht_cap sta_ht_cap;
4394
4395 if (is_ibss) {
4396 ret = wl1271_bss_beacon_info_changed(wl, vif, bss_conf,
4397 changed);
4398 if (ret < 0)
4399 goto out;
4400 }
4401
4402 if (changed & BSS_CHANGED_IBSS) {
4403 if (bss_conf->ibss_joined) {
4404 set_bit(WLVIF_FLAG_IBSS_JOINED, &wlvif->flags);
4405 ibss_joined = true;
4406 } else {
4407 wlcore_unset_assoc(wl, wlvif);
4408 wl12xx_cmd_role_stop_sta(wl, wlvif);
4409 }
4410 }
4411
4412 if ((changed & BSS_CHANGED_BEACON_INT) && ibss_joined)
4413 do_join = true;
4414
4415 /* Need to update the SSID (for filtering etc) */
4416 if ((changed & BSS_CHANGED_BEACON) && ibss_joined)
4417 do_join = true;
4418
4419 if ((changed & BSS_CHANGED_BEACON_ENABLED) && ibss_joined) {
4420 wl1271_debug(DEBUG_ADHOC, "ad-hoc beaconing: %s",
4421 bss_conf->enable_beacon ? "enabled" : "disabled");
4422
4423 do_join = true;
4424 }
4425
4426 if (changed & BSS_CHANGED_IDLE && !is_ibss)
4427 wl1271_sta_handle_idle(wl, wlvif, bss_conf->idle);
4428
4429 if (changed & BSS_CHANGED_CQM) {
4430 bool enable = false;
4431 if (bss_conf->cqm_rssi_thold)
4432 enable = true;
4433 ret = wl1271_acx_rssi_snr_trigger(wl, wlvif, enable,
4434 bss_conf->cqm_rssi_thold,
4435 bss_conf->cqm_rssi_hyst);
4436 if (ret < 0)
4437 goto out;
4438 wlvif->rssi_thold = bss_conf->cqm_rssi_thold;
4439 }
4440
4441 if (changed & (BSS_CHANGED_BSSID | BSS_CHANGED_HT |
4442 BSS_CHANGED_ASSOC)) {
4443 rcu_read_lock();
4444 sta = ieee80211_find_sta(vif, bss_conf->bssid);
4445 if (sta) {
4446 u8 *rx_mask = sta->ht_cap.mcs.rx_mask;
4447
4448 /* save the supp_rates of the ap */
4449 sta_rate_set = sta->supp_rates[wlvif->band];
4450 if (sta->ht_cap.ht_supported)
4451 sta_rate_set |=
4452 (rx_mask[0] << HW_HT_RATES_OFFSET) |
4453 (rx_mask[1] << HW_MIMO_RATES_OFFSET);
4454 sta_ht_cap = sta->ht_cap;
4455 sta_exists = true;
4456 }
4457
4458 rcu_read_unlock();
4459 }
4460
4461 if (changed & BSS_CHANGED_BSSID) {
4462 if (!is_zero_ether_addr(bss_conf->bssid)) {
4463 ret = wlcore_set_bssid(wl, wlvif, bss_conf,
4464 sta_rate_set);
4465 if (ret < 0)
4466 goto out;
4467
4468 /* Need to update the BSSID (for filtering etc) */
4469 do_join = true;
4470 } else {
4471 ret = wlcore_clear_bssid(wl, wlvif);
4472 if (ret < 0)
4473 goto out;
4474 }
4475 }
4476
4477 if (changed & BSS_CHANGED_IBSS) {
4478 wl1271_debug(DEBUG_ADHOC, "ibss_joined: %d",
4479 bss_conf->ibss_joined);
4480
4481 if (bss_conf->ibss_joined) {
4482 u32 rates = bss_conf->basic_rates;
4483 wlvif->basic_rate_set =
4484 wl1271_tx_enabled_rates_get(wl, rates,
4485 wlvif->band);
4486 wlvif->basic_rate =
4487 wl1271_tx_min_rate_get(wl,
4488 wlvif->basic_rate_set);
4489
4490 /* by default, use 11b + OFDM rates */
4491 wlvif->rate_set = CONF_TX_IBSS_DEFAULT_RATES;
4492 ret = wl1271_acx_sta_rate_policies(wl, wlvif);
4493 if (ret < 0)
4494 goto out;
4495 }
4496 }
4497
4498 if ((changed & BSS_CHANGED_BEACON_INFO) && bss_conf->dtim_period) {
4499 /* enable beacon filtering */
4500 ret = wl1271_acx_beacon_filter_opt(wl, wlvif, true);
4501 if (ret < 0)
4502 goto out;
4503 }
4504
4505 ret = wl1271_bss_erp_info_changed(wl, vif, bss_conf, changed);
4506 if (ret < 0)
4507 goto out;
4508
4509 if (do_join) {
4510 ret = wlcore_join(wl, wlvif);
4511 if (ret < 0) {
4512 wl1271_warning("cmd join failed %d", ret);
4513 goto out;
4514 }
4515 }
4516
4517 if (changed & BSS_CHANGED_ASSOC) {
4518 if (bss_conf->assoc) {
4519 ret = wlcore_set_assoc(wl, wlvif, bss_conf,
4520 sta_rate_set);
4521 if (ret < 0)
4522 goto out;
4523
4524 if (test_bit(WLVIF_FLAG_STA_AUTHORIZED, &wlvif->flags))
4525 wl12xx_set_authorized(wl, wlvif);
4526 } else {
4527 wlcore_unset_assoc(wl, wlvif);
4528 }
4529 }
4530
4531 if (changed & BSS_CHANGED_PS) {
4532 if ((bss_conf->ps) &&
4533 test_bit(WLVIF_FLAG_STA_ASSOCIATED, &wlvif->flags) &&
4534 !test_bit(WLVIF_FLAG_IN_PS, &wlvif->flags)) {
4535 int ps_mode;
4536 char *ps_mode_str;
4537
4538 if (wl->conf.conn.forced_ps) {
4539 ps_mode = STATION_POWER_SAVE_MODE;
4540 ps_mode_str = "forced";
4541 } else {
4542 ps_mode = STATION_AUTO_PS_MODE;
4543 ps_mode_str = "auto";
4544 }
4545
4546 wl1271_debug(DEBUG_PSM, "%s ps enabled", ps_mode_str);
4547
4548 ret = wl1271_ps_set_mode(wl, wlvif, ps_mode);
4549 if (ret < 0)
4550 wl1271_warning("enter %s ps failed %d",
4551 ps_mode_str, ret);
4552 } else if (!bss_conf->ps &&
4553 test_bit(WLVIF_FLAG_IN_PS, &wlvif->flags)) {
4554 wl1271_debug(DEBUG_PSM, "auto ps disabled");
4555
4556 ret = wl1271_ps_set_mode(wl, wlvif,
4557 STATION_ACTIVE_MODE);
4558 if (ret < 0)
4559 wl1271_warning("exit auto ps failed %d", ret);
4560 }
4561 }
4562
4563 /* Handle new association with HT. Do this after join. */
4564 if (sta_exists) {
4565 bool enabled =
4566 bss_conf->chandef.width != NL80211_CHAN_WIDTH_20_NOHT;
4567
4568 ret = wlcore_hw_set_peer_cap(wl,
4569 &sta_ht_cap,
4570 enabled,
4571 wlvif->rate_set,
4572 wlvif->sta.hlid);
4573 if (ret < 0) {
4574 wl1271_warning("Set ht cap failed %d", ret);
4575 goto out;
4576
4577 }
4578
4579 if (enabled) {
4580 ret = wl1271_acx_set_ht_information(wl, wlvif,
4581 bss_conf->ht_operation_mode);
4582 if (ret < 0) {
4583 wl1271_warning("Set ht information failed %d",
4584 ret);
4585 goto out;
4586 }
4587 }
4588 }
4589
4590 /* Handle arp filtering. Done after join. */
4591 if ((changed & BSS_CHANGED_ARP_FILTER) ||
4592 (!is_ibss && (changed & BSS_CHANGED_QOS))) {
4593 __be32 addr = bss_conf->arp_addr_list[0];
4594 wlvif->sta.qos = bss_conf->qos;
4595 WARN_ON(wlvif->bss_type != BSS_TYPE_STA_BSS);
4596
4597 if (bss_conf->arp_addr_cnt == 1 && bss_conf->assoc) {
4598 wlvif->ip_addr = addr;
4599 /*
4600 * The template should have been configured only upon
4601 * association. however, it seems that the correct ip
4602 * isn't being set (when sending), so we have to
4603 * reconfigure the template upon every ip change.
4604 */
4605 ret = wl1271_cmd_build_arp_rsp(wl, wlvif);
4606 if (ret < 0) {
4607 wl1271_warning("build arp rsp failed: %d", ret);
4608 goto out;
4609 }
4610
4611 ret = wl1271_acx_arp_ip_filter(wl, wlvif,
4612 (ACX_ARP_FILTER_ARP_FILTERING |
4613 ACX_ARP_FILTER_AUTO_ARP),
4614 addr);
4615 } else {
4616 wlvif->ip_addr = 0;
4617 ret = wl1271_acx_arp_ip_filter(wl, wlvif, 0, addr);
4618 }
4619
4620 if (ret < 0)
4621 goto out;
4622 }
4623
4624 out:
4625 return;
4626 }
4627
wl1271_op_bss_info_changed(struct ieee80211_hw * hw,struct ieee80211_vif * vif,struct ieee80211_bss_conf * bss_conf,u32 changed)4628 static void wl1271_op_bss_info_changed(struct ieee80211_hw *hw,
4629 struct ieee80211_vif *vif,
4630 struct ieee80211_bss_conf *bss_conf,
4631 u32 changed)
4632 {
4633 struct wl1271 *wl = hw->priv;
4634 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
4635 bool is_ap = (wlvif->bss_type == BSS_TYPE_AP_BSS);
4636 int ret;
4637
4638 wl1271_debug(DEBUG_MAC80211, "mac80211 bss info role %d changed 0x%x",
4639 wlvif->role_id, (int)changed);
4640
4641 /*
4642 * make sure to cancel pending disconnections if our association
4643 * state changed
4644 */
4645 if (!is_ap && (changed & BSS_CHANGED_ASSOC))
4646 cancel_delayed_work_sync(&wlvif->connection_loss_work);
4647
4648 if (is_ap && (changed & BSS_CHANGED_BEACON_ENABLED) &&
4649 !bss_conf->enable_beacon)
4650 wl1271_tx_flush(wl);
4651
4652 mutex_lock(&wl->mutex);
4653
4654 if (unlikely(wl->state != WLCORE_STATE_ON))
4655 goto out;
4656
4657 if (unlikely(!test_bit(WLVIF_FLAG_INITIALIZED, &wlvif->flags)))
4658 goto out;
4659
4660 ret = pm_runtime_get_sync(wl->dev);
4661 if (ret < 0) {
4662 pm_runtime_put_noidle(wl->dev);
4663 goto out;
4664 }
4665
4666 if ((changed & BSS_CHANGED_TXPOWER) &&
4667 bss_conf->txpower != wlvif->power_level) {
4668
4669 ret = wl1271_acx_tx_power(wl, wlvif, bss_conf->txpower);
4670 if (ret < 0)
4671 goto out;
4672
4673 wlvif->power_level = bss_conf->txpower;
4674 }
4675
4676 if (is_ap)
4677 wl1271_bss_info_changed_ap(wl, vif, bss_conf, changed);
4678 else
4679 wl1271_bss_info_changed_sta(wl, vif, bss_conf, changed);
4680
4681 pm_runtime_mark_last_busy(wl->dev);
4682 pm_runtime_put_autosuspend(wl->dev);
4683
4684 out:
4685 mutex_unlock(&wl->mutex);
4686 }
4687
wlcore_op_add_chanctx(struct ieee80211_hw * hw,struct ieee80211_chanctx_conf * ctx)4688 static int wlcore_op_add_chanctx(struct ieee80211_hw *hw,
4689 struct ieee80211_chanctx_conf *ctx)
4690 {
4691 wl1271_debug(DEBUG_MAC80211, "mac80211 add chanctx %d (type %d)",
4692 ieee80211_frequency_to_channel(ctx->def.chan->center_freq),
4693 cfg80211_get_chandef_type(&ctx->def));
4694 return 0;
4695 }
4696
wlcore_op_remove_chanctx(struct ieee80211_hw * hw,struct ieee80211_chanctx_conf * ctx)4697 static void wlcore_op_remove_chanctx(struct ieee80211_hw *hw,
4698 struct ieee80211_chanctx_conf *ctx)
4699 {
4700 wl1271_debug(DEBUG_MAC80211, "mac80211 remove chanctx %d (type %d)",
4701 ieee80211_frequency_to_channel(ctx->def.chan->center_freq),
4702 cfg80211_get_chandef_type(&ctx->def));
4703 }
4704
wlcore_op_change_chanctx(struct ieee80211_hw * hw,struct ieee80211_chanctx_conf * ctx,u32 changed)4705 static void wlcore_op_change_chanctx(struct ieee80211_hw *hw,
4706 struct ieee80211_chanctx_conf *ctx,
4707 u32 changed)
4708 {
4709 struct wl1271 *wl = hw->priv;
4710 struct wl12xx_vif *wlvif;
4711 int ret;
4712 int channel = ieee80211_frequency_to_channel(
4713 ctx->def.chan->center_freq);
4714
4715 wl1271_debug(DEBUG_MAC80211,
4716 "mac80211 change chanctx %d (type %d) changed 0x%x",
4717 channel, cfg80211_get_chandef_type(&ctx->def), changed);
4718
4719 mutex_lock(&wl->mutex);
4720
4721 ret = pm_runtime_get_sync(wl->dev);
4722 if (ret < 0) {
4723 pm_runtime_put_noidle(wl->dev);
4724 goto out;
4725 }
4726
4727 wl12xx_for_each_wlvif(wl, wlvif) {
4728 struct ieee80211_vif *vif = wl12xx_wlvif_to_vif(wlvif);
4729
4730 rcu_read_lock();
4731 if (rcu_access_pointer(vif->chanctx_conf) != ctx) {
4732 rcu_read_unlock();
4733 continue;
4734 }
4735 rcu_read_unlock();
4736
4737 /* start radar if needed */
4738 if (changed & IEEE80211_CHANCTX_CHANGE_RADAR &&
4739 wlvif->bss_type == BSS_TYPE_AP_BSS &&
4740 ctx->radar_enabled && !wlvif->radar_enabled &&
4741 ctx->def.chan->dfs_state == NL80211_DFS_USABLE) {
4742 wl1271_debug(DEBUG_MAC80211, "Start radar detection");
4743 wlcore_hw_set_cac(wl, wlvif, true);
4744 wlvif->radar_enabled = true;
4745 }
4746 }
4747
4748 pm_runtime_mark_last_busy(wl->dev);
4749 pm_runtime_put_autosuspend(wl->dev);
4750 out:
4751 mutex_unlock(&wl->mutex);
4752 }
4753
wlcore_op_assign_vif_chanctx(struct ieee80211_hw * hw,struct ieee80211_vif * vif,struct ieee80211_chanctx_conf * ctx)4754 static int wlcore_op_assign_vif_chanctx(struct ieee80211_hw *hw,
4755 struct ieee80211_vif *vif,
4756 struct ieee80211_chanctx_conf *ctx)
4757 {
4758 struct wl1271 *wl = hw->priv;
4759 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
4760 int channel = ieee80211_frequency_to_channel(
4761 ctx->def.chan->center_freq);
4762 int ret = -EINVAL;
4763
4764 wl1271_debug(DEBUG_MAC80211,
4765 "mac80211 assign chanctx (role %d) %d (type %d) (radar %d dfs_state %d)",
4766 wlvif->role_id, channel,
4767 cfg80211_get_chandef_type(&ctx->def),
4768 ctx->radar_enabled, ctx->def.chan->dfs_state);
4769
4770 mutex_lock(&wl->mutex);
4771
4772 if (unlikely(wl->state != WLCORE_STATE_ON))
4773 goto out;
4774
4775 if (unlikely(!test_bit(WLVIF_FLAG_INITIALIZED, &wlvif->flags)))
4776 goto out;
4777
4778 ret = pm_runtime_get_sync(wl->dev);
4779 if (ret < 0) {
4780 pm_runtime_put_noidle(wl->dev);
4781 goto out;
4782 }
4783
4784 wlvif->band = ctx->def.chan->band;
4785 wlvif->channel = channel;
4786 wlvif->channel_type = cfg80211_get_chandef_type(&ctx->def);
4787
4788 /* update default rates according to the band */
4789 wl1271_set_band_rate(wl, wlvif);
4790
4791 if (ctx->radar_enabled &&
4792 ctx->def.chan->dfs_state == NL80211_DFS_USABLE) {
4793 wl1271_debug(DEBUG_MAC80211, "Start radar detection");
4794 wlcore_hw_set_cac(wl, wlvif, true);
4795 wlvif->radar_enabled = true;
4796 }
4797
4798 pm_runtime_mark_last_busy(wl->dev);
4799 pm_runtime_put_autosuspend(wl->dev);
4800 out:
4801 mutex_unlock(&wl->mutex);
4802
4803 return 0;
4804 }
4805
wlcore_op_unassign_vif_chanctx(struct ieee80211_hw * hw,struct ieee80211_vif * vif,struct ieee80211_chanctx_conf * ctx)4806 static void wlcore_op_unassign_vif_chanctx(struct ieee80211_hw *hw,
4807 struct ieee80211_vif *vif,
4808 struct ieee80211_chanctx_conf *ctx)
4809 {
4810 struct wl1271 *wl = hw->priv;
4811 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
4812 int ret;
4813
4814 wl1271_debug(DEBUG_MAC80211,
4815 "mac80211 unassign chanctx (role %d) %d (type %d)",
4816 wlvif->role_id,
4817 ieee80211_frequency_to_channel(ctx->def.chan->center_freq),
4818 cfg80211_get_chandef_type(&ctx->def));
4819
4820 wl1271_tx_flush(wl);
4821
4822 mutex_lock(&wl->mutex);
4823
4824 if (unlikely(wl->state != WLCORE_STATE_ON))
4825 goto out;
4826
4827 if (unlikely(!test_bit(WLVIF_FLAG_INITIALIZED, &wlvif->flags)))
4828 goto out;
4829
4830 ret = pm_runtime_get_sync(wl->dev);
4831 if (ret < 0) {
4832 pm_runtime_put_noidle(wl->dev);
4833 goto out;
4834 }
4835
4836 if (wlvif->radar_enabled) {
4837 wl1271_debug(DEBUG_MAC80211, "Stop radar detection");
4838 wlcore_hw_set_cac(wl, wlvif, false);
4839 wlvif->radar_enabled = false;
4840 }
4841
4842 pm_runtime_mark_last_busy(wl->dev);
4843 pm_runtime_put_autosuspend(wl->dev);
4844 out:
4845 mutex_unlock(&wl->mutex);
4846 }
4847
__wlcore_switch_vif_chan(struct wl1271 * wl,struct wl12xx_vif * wlvif,struct ieee80211_chanctx_conf * new_ctx)4848 static int __wlcore_switch_vif_chan(struct wl1271 *wl,
4849 struct wl12xx_vif *wlvif,
4850 struct ieee80211_chanctx_conf *new_ctx)
4851 {
4852 int channel = ieee80211_frequency_to_channel(
4853 new_ctx->def.chan->center_freq);
4854
4855 wl1271_debug(DEBUG_MAC80211,
4856 "switch vif (role %d) %d -> %d chan_type: %d",
4857 wlvif->role_id, wlvif->channel, channel,
4858 cfg80211_get_chandef_type(&new_ctx->def));
4859
4860 if (WARN_ON_ONCE(wlvif->bss_type != BSS_TYPE_AP_BSS))
4861 return 0;
4862
4863 WARN_ON(!test_bit(WLVIF_FLAG_BEACON_DISABLED, &wlvif->flags));
4864
4865 if (wlvif->radar_enabled) {
4866 wl1271_debug(DEBUG_MAC80211, "Stop radar detection");
4867 wlcore_hw_set_cac(wl, wlvif, false);
4868 wlvif->radar_enabled = false;
4869 }
4870
4871 wlvif->band = new_ctx->def.chan->band;
4872 wlvif->channel = channel;
4873 wlvif->channel_type = cfg80211_get_chandef_type(&new_ctx->def);
4874
4875 /* start radar if needed */
4876 if (new_ctx->radar_enabled) {
4877 wl1271_debug(DEBUG_MAC80211, "Start radar detection");
4878 wlcore_hw_set_cac(wl, wlvif, true);
4879 wlvif->radar_enabled = true;
4880 }
4881
4882 return 0;
4883 }
4884
4885 static int
wlcore_op_switch_vif_chanctx(struct ieee80211_hw * hw,struct ieee80211_vif_chanctx_switch * vifs,int n_vifs,enum ieee80211_chanctx_switch_mode mode)4886 wlcore_op_switch_vif_chanctx(struct ieee80211_hw *hw,
4887 struct ieee80211_vif_chanctx_switch *vifs,
4888 int n_vifs,
4889 enum ieee80211_chanctx_switch_mode mode)
4890 {
4891 struct wl1271 *wl = hw->priv;
4892 int i, ret;
4893
4894 wl1271_debug(DEBUG_MAC80211,
4895 "mac80211 switch chanctx n_vifs %d mode %d",
4896 n_vifs, mode);
4897
4898 mutex_lock(&wl->mutex);
4899
4900 ret = pm_runtime_get_sync(wl->dev);
4901 if (ret < 0) {
4902 pm_runtime_put_noidle(wl->dev);
4903 goto out;
4904 }
4905
4906 for (i = 0; i < n_vifs; i++) {
4907 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vifs[i].vif);
4908
4909 ret = __wlcore_switch_vif_chan(wl, wlvif, vifs[i].new_ctx);
4910 if (ret)
4911 goto out_sleep;
4912 }
4913 out_sleep:
4914 pm_runtime_mark_last_busy(wl->dev);
4915 pm_runtime_put_autosuspend(wl->dev);
4916 out:
4917 mutex_unlock(&wl->mutex);
4918
4919 return 0;
4920 }
4921
wl1271_op_conf_tx(struct ieee80211_hw * hw,struct ieee80211_vif * vif,u16 queue,const struct ieee80211_tx_queue_params * params)4922 static int wl1271_op_conf_tx(struct ieee80211_hw *hw,
4923 struct ieee80211_vif *vif, u16 queue,
4924 const struct ieee80211_tx_queue_params *params)
4925 {
4926 struct wl1271 *wl = hw->priv;
4927 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
4928 u8 ps_scheme;
4929 int ret = 0;
4930
4931 if (wlcore_is_p2p_mgmt(wlvif))
4932 return 0;
4933
4934 mutex_lock(&wl->mutex);
4935
4936 wl1271_debug(DEBUG_MAC80211, "mac80211 conf tx %d", queue);
4937
4938 if (params->uapsd)
4939 ps_scheme = CONF_PS_SCHEME_UPSD_TRIGGER;
4940 else
4941 ps_scheme = CONF_PS_SCHEME_LEGACY;
4942
4943 if (!test_bit(WLVIF_FLAG_INITIALIZED, &wlvif->flags))
4944 goto out;
4945
4946 ret = pm_runtime_get_sync(wl->dev);
4947 if (ret < 0) {
4948 pm_runtime_put_noidle(wl->dev);
4949 goto out;
4950 }
4951
4952 /*
4953 * the txop is confed in units of 32us by the mac80211,
4954 * we need us
4955 */
4956 ret = wl1271_acx_ac_cfg(wl, wlvif, wl1271_tx_get_queue(queue),
4957 params->cw_min, params->cw_max,
4958 params->aifs, params->txop << 5);
4959 if (ret < 0)
4960 goto out_sleep;
4961
4962 ret = wl1271_acx_tid_cfg(wl, wlvif, wl1271_tx_get_queue(queue),
4963 CONF_CHANNEL_TYPE_EDCF,
4964 wl1271_tx_get_queue(queue),
4965 ps_scheme, CONF_ACK_POLICY_LEGACY,
4966 0, 0);
4967
4968 out_sleep:
4969 pm_runtime_mark_last_busy(wl->dev);
4970 pm_runtime_put_autosuspend(wl->dev);
4971
4972 out:
4973 mutex_unlock(&wl->mutex);
4974
4975 return ret;
4976 }
4977
wl1271_op_get_tsf(struct ieee80211_hw * hw,struct ieee80211_vif * vif)4978 static u64 wl1271_op_get_tsf(struct ieee80211_hw *hw,
4979 struct ieee80211_vif *vif)
4980 {
4981
4982 struct wl1271 *wl = hw->priv;
4983 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
4984 u64 mactime = ULLONG_MAX;
4985 int ret;
4986
4987 wl1271_debug(DEBUG_MAC80211, "mac80211 get tsf");
4988
4989 mutex_lock(&wl->mutex);
4990
4991 if (unlikely(wl->state != WLCORE_STATE_ON))
4992 goto out;
4993
4994 ret = pm_runtime_get_sync(wl->dev);
4995 if (ret < 0) {
4996 pm_runtime_put_noidle(wl->dev);
4997 goto out;
4998 }
4999
5000 ret = wl12xx_acx_tsf_info(wl, wlvif, &mactime);
5001 if (ret < 0)
5002 goto out_sleep;
5003
5004 out_sleep:
5005 pm_runtime_mark_last_busy(wl->dev);
5006 pm_runtime_put_autosuspend(wl->dev);
5007
5008 out:
5009 mutex_unlock(&wl->mutex);
5010 return mactime;
5011 }
5012
wl1271_op_get_survey(struct ieee80211_hw * hw,int idx,struct survey_info * survey)5013 static int wl1271_op_get_survey(struct ieee80211_hw *hw, int idx,
5014 struct survey_info *survey)
5015 {
5016 struct ieee80211_conf *conf = &hw->conf;
5017
5018 if (idx != 0)
5019 return -ENOENT;
5020
5021 survey->channel = conf->chandef.chan;
5022 survey->filled = 0;
5023 return 0;
5024 }
5025
wl1271_allocate_sta(struct wl1271 * wl,struct wl12xx_vif * wlvif,struct ieee80211_sta * sta)5026 static int wl1271_allocate_sta(struct wl1271 *wl,
5027 struct wl12xx_vif *wlvif,
5028 struct ieee80211_sta *sta)
5029 {
5030 struct wl1271_station *wl_sta;
5031 int ret;
5032
5033
5034 if (wl->active_sta_count >= wl->max_ap_stations) {
5035 wl1271_warning("could not allocate HLID - too much stations");
5036 return -EBUSY;
5037 }
5038
5039 wl_sta = (struct wl1271_station *)sta->drv_priv;
5040 ret = wl12xx_allocate_link(wl, wlvif, &wl_sta->hlid);
5041 if (ret < 0) {
5042 wl1271_warning("could not allocate HLID - too many links");
5043 return -EBUSY;
5044 }
5045
5046 /* use the previous security seq, if this is a recovery/resume */
5047 wl->links[wl_sta->hlid].total_freed_pkts = wl_sta->total_freed_pkts;
5048
5049 set_bit(wl_sta->hlid, wlvif->ap.sta_hlid_map);
5050 memcpy(wl->links[wl_sta->hlid].addr, sta->addr, ETH_ALEN);
5051 wl->active_sta_count++;
5052 return 0;
5053 }
5054
wl1271_free_sta(struct wl1271 * wl,struct wl12xx_vif * wlvif,u8 hlid)5055 void wl1271_free_sta(struct wl1271 *wl, struct wl12xx_vif *wlvif, u8 hlid)
5056 {
5057 if (!test_bit(hlid, wlvif->ap.sta_hlid_map))
5058 return;
5059
5060 clear_bit(hlid, wlvif->ap.sta_hlid_map);
5061 __clear_bit(hlid, &wl->ap_ps_map);
5062 __clear_bit(hlid, &wl->ap_fw_ps_map);
5063
5064 /*
5065 * save the last used PN in the private part of iee80211_sta,
5066 * in case of recovery/suspend
5067 */
5068 wlcore_save_freed_pkts_addr(wl, wlvif, hlid, wl->links[hlid].addr);
5069
5070 wl12xx_free_link(wl, wlvif, &hlid);
5071 wl->active_sta_count--;
5072
5073 /*
5074 * rearm the tx watchdog when the last STA is freed - give the FW a
5075 * chance to return STA-buffered packets before complaining.
5076 */
5077 if (wl->active_sta_count == 0)
5078 wl12xx_rearm_tx_watchdog_locked(wl);
5079 }
5080
wl12xx_sta_add(struct wl1271 * wl,struct wl12xx_vif * wlvif,struct ieee80211_sta * sta)5081 static int wl12xx_sta_add(struct wl1271 *wl,
5082 struct wl12xx_vif *wlvif,
5083 struct ieee80211_sta *sta)
5084 {
5085 struct wl1271_station *wl_sta;
5086 int ret = 0;
5087 u8 hlid;
5088
5089 wl1271_debug(DEBUG_MAC80211, "mac80211 add sta %d", (int)sta->aid);
5090
5091 ret = wl1271_allocate_sta(wl, wlvif, sta);
5092 if (ret < 0)
5093 return ret;
5094
5095 wl_sta = (struct wl1271_station *)sta->drv_priv;
5096 hlid = wl_sta->hlid;
5097
5098 ret = wl12xx_cmd_add_peer(wl, wlvif, sta, hlid);
5099 if (ret < 0)
5100 wl1271_free_sta(wl, wlvif, hlid);
5101
5102 return ret;
5103 }
5104
wl12xx_sta_remove(struct wl1271 * wl,struct wl12xx_vif * wlvif,struct ieee80211_sta * sta)5105 static int wl12xx_sta_remove(struct wl1271 *wl,
5106 struct wl12xx_vif *wlvif,
5107 struct ieee80211_sta *sta)
5108 {
5109 struct wl1271_station *wl_sta;
5110 int ret = 0, id;
5111
5112 wl1271_debug(DEBUG_MAC80211, "mac80211 remove sta %d", (int)sta->aid);
5113
5114 wl_sta = (struct wl1271_station *)sta->drv_priv;
5115 id = wl_sta->hlid;
5116 if (WARN_ON(!test_bit(id, wlvif->ap.sta_hlid_map)))
5117 return -EINVAL;
5118
5119 ret = wl12xx_cmd_remove_peer(wl, wlvif, wl_sta->hlid);
5120 if (ret < 0)
5121 return ret;
5122
5123 wl1271_free_sta(wl, wlvif, wl_sta->hlid);
5124 return ret;
5125 }
5126
wlcore_roc_if_possible(struct wl1271 * wl,struct wl12xx_vif * wlvif)5127 static void wlcore_roc_if_possible(struct wl1271 *wl,
5128 struct wl12xx_vif *wlvif)
5129 {
5130 if (find_first_bit(wl->roc_map,
5131 WL12XX_MAX_ROLES) < WL12XX_MAX_ROLES)
5132 return;
5133
5134 if (WARN_ON(wlvif->role_id == WL12XX_INVALID_ROLE_ID))
5135 return;
5136
5137 wl12xx_roc(wl, wlvif, wlvif->role_id, wlvif->band, wlvif->channel);
5138 }
5139
5140 /*
5141 * when wl_sta is NULL, we treat this call as if coming from a
5142 * pending auth reply.
5143 * wl->mutex must be taken and the FW must be awake when the call
5144 * takes place.
5145 */
wlcore_update_inconn_sta(struct wl1271 * wl,struct wl12xx_vif * wlvif,struct wl1271_station * wl_sta,bool in_conn)5146 void wlcore_update_inconn_sta(struct wl1271 *wl, struct wl12xx_vif *wlvif,
5147 struct wl1271_station *wl_sta, bool in_conn)
5148 {
5149 if (in_conn) {
5150 if (WARN_ON(wl_sta && wl_sta->in_connection))
5151 return;
5152
5153 if (!wlvif->ap_pending_auth_reply &&
5154 !wlvif->inconn_count)
5155 wlcore_roc_if_possible(wl, wlvif);
5156
5157 if (wl_sta) {
5158 wl_sta->in_connection = true;
5159 wlvif->inconn_count++;
5160 } else {
5161 wlvif->ap_pending_auth_reply = true;
5162 }
5163 } else {
5164 if (wl_sta && !wl_sta->in_connection)
5165 return;
5166
5167 if (WARN_ON(!wl_sta && !wlvif->ap_pending_auth_reply))
5168 return;
5169
5170 if (WARN_ON(wl_sta && !wlvif->inconn_count))
5171 return;
5172
5173 if (wl_sta) {
5174 wl_sta->in_connection = false;
5175 wlvif->inconn_count--;
5176 } else {
5177 wlvif->ap_pending_auth_reply = false;
5178 }
5179
5180 if (!wlvif->inconn_count && !wlvif->ap_pending_auth_reply &&
5181 test_bit(wlvif->role_id, wl->roc_map))
5182 wl12xx_croc(wl, wlvif->role_id);
5183 }
5184 }
5185
wl12xx_update_sta_state(struct wl1271 * wl,struct wl12xx_vif * wlvif,struct ieee80211_sta * sta,enum ieee80211_sta_state old_state,enum ieee80211_sta_state new_state)5186 static int wl12xx_update_sta_state(struct wl1271 *wl,
5187 struct wl12xx_vif *wlvif,
5188 struct ieee80211_sta *sta,
5189 enum ieee80211_sta_state old_state,
5190 enum ieee80211_sta_state new_state)
5191 {
5192 struct wl1271_station *wl_sta;
5193 bool is_ap = wlvif->bss_type == BSS_TYPE_AP_BSS;
5194 bool is_sta = wlvif->bss_type == BSS_TYPE_STA_BSS;
5195 int ret;
5196
5197 wl_sta = (struct wl1271_station *)sta->drv_priv;
5198
5199 /* Add station (AP mode) */
5200 if (is_ap &&
5201 old_state == IEEE80211_STA_NOTEXIST &&
5202 new_state == IEEE80211_STA_NONE) {
5203 ret = wl12xx_sta_add(wl, wlvif, sta);
5204 if (ret)
5205 return ret;
5206
5207 wlcore_update_inconn_sta(wl, wlvif, wl_sta, true);
5208 }
5209
5210 /* Remove station (AP mode) */
5211 if (is_ap &&
5212 old_state == IEEE80211_STA_NONE &&
5213 new_state == IEEE80211_STA_NOTEXIST) {
5214 /* must not fail */
5215 wl12xx_sta_remove(wl, wlvif, sta);
5216
5217 wlcore_update_inconn_sta(wl, wlvif, wl_sta, false);
5218 }
5219
5220 /* Authorize station (AP mode) */
5221 if (is_ap &&
5222 new_state == IEEE80211_STA_AUTHORIZED) {
5223 ret = wl12xx_cmd_set_peer_state(wl, wlvif, wl_sta->hlid);
5224 if (ret < 0)
5225 return ret;
5226
5227 /* reconfigure rates */
5228 ret = wl12xx_cmd_add_peer(wl, wlvif, sta, wl_sta->hlid);
5229 if (ret < 0)
5230 return ret;
5231
5232 ret = wl1271_acx_set_ht_capabilities(wl, &sta->ht_cap, true,
5233 wl_sta->hlid);
5234 if (ret)
5235 return ret;
5236
5237 wlcore_update_inconn_sta(wl, wlvif, wl_sta, false);
5238 }
5239
5240 /* Authorize station */
5241 if (is_sta &&
5242 new_state == IEEE80211_STA_AUTHORIZED) {
5243 set_bit(WLVIF_FLAG_STA_AUTHORIZED, &wlvif->flags);
5244 ret = wl12xx_set_authorized(wl, wlvif);
5245 if (ret)
5246 return ret;
5247 }
5248
5249 if (is_sta &&
5250 old_state == IEEE80211_STA_AUTHORIZED &&
5251 new_state == IEEE80211_STA_ASSOC) {
5252 clear_bit(WLVIF_FLAG_STA_AUTHORIZED, &wlvif->flags);
5253 clear_bit(WLVIF_FLAG_STA_STATE_SENT, &wlvif->flags);
5254 }
5255
5256 /* save seq number on disassoc (suspend) */
5257 if (is_sta &&
5258 old_state == IEEE80211_STA_ASSOC &&
5259 new_state == IEEE80211_STA_AUTH) {
5260 wlcore_save_freed_pkts(wl, wlvif, wlvif->sta.hlid, sta);
5261 wlvif->total_freed_pkts = 0;
5262 }
5263
5264 /* restore seq number on assoc (resume) */
5265 if (is_sta &&
5266 old_state == IEEE80211_STA_AUTH &&
5267 new_state == IEEE80211_STA_ASSOC) {
5268 wlvif->total_freed_pkts = wl_sta->total_freed_pkts;
5269 }
5270
5271 /* clear ROCs on failure or authorization */
5272 if (is_sta &&
5273 (new_state == IEEE80211_STA_AUTHORIZED ||
5274 new_state == IEEE80211_STA_NOTEXIST)) {
5275 if (test_bit(wlvif->role_id, wl->roc_map))
5276 wl12xx_croc(wl, wlvif->role_id);
5277 }
5278
5279 if (is_sta &&
5280 old_state == IEEE80211_STA_NOTEXIST &&
5281 new_state == IEEE80211_STA_NONE) {
5282 if (find_first_bit(wl->roc_map,
5283 WL12XX_MAX_ROLES) >= WL12XX_MAX_ROLES) {
5284 WARN_ON(wlvif->role_id == WL12XX_INVALID_ROLE_ID);
5285 wl12xx_roc(wl, wlvif, wlvif->role_id,
5286 wlvif->band, wlvif->channel);
5287 }
5288 }
5289 return 0;
5290 }
5291
wl12xx_op_sta_state(struct ieee80211_hw * hw,struct ieee80211_vif * vif,struct ieee80211_sta * sta,enum ieee80211_sta_state old_state,enum ieee80211_sta_state new_state)5292 static int wl12xx_op_sta_state(struct ieee80211_hw *hw,
5293 struct ieee80211_vif *vif,
5294 struct ieee80211_sta *sta,
5295 enum ieee80211_sta_state old_state,
5296 enum ieee80211_sta_state new_state)
5297 {
5298 struct wl1271 *wl = hw->priv;
5299 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
5300 int ret;
5301
5302 wl1271_debug(DEBUG_MAC80211, "mac80211 sta %d state=%d->%d",
5303 sta->aid, old_state, new_state);
5304
5305 mutex_lock(&wl->mutex);
5306
5307 if (unlikely(wl->state != WLCORE_STATE_ON)) {
5308 ret = -EBUSY;
5309 goto out;
5310 }
5311
5312 ret = pm_runtime_get_sync(wl->dev);
5313 if (ret < 0) {
5314 pm_runtime_put_noidle(wl->dev);
5315 goto out;
5316 }
5317
5318 ret = wl12xx_update_sta_state(wl, wlvif, sta, old_state, new_state);
5319
5320 pm_runtime_mark_last_busy(wl->dev);
5321 pm_runtime_put_autosuspend(wl->dev);
5322 out:
5323 mutex_unlock(&wl->mutex);
5324 if (new_state < old_state)
5325 return 0;
5326 return ret;
5327 }
5328
wl1271_op_ampdu_action(struct ieee80211_hw * hw,struct ieee80211_vif * vif,struct ieee80211_ampdu_params * params)5329 static int wl1271_op_ampdu_action(struct ieee80211_hw *hw,
5330 struct ieee80211_vif *vif,
5331 struct ieee80211_ampdu_params *params)
5332 {
5333 struct wl1271 *wl = hw->priv;
5334 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
5335 int ret;
5336 u8 hlid, *ba_bitmap;
5337 struct ieee80211_sta *sta = params->sta;
5338 enum ieee80211_ampdu_mlme_action action = params->action;
5339 u16 tid = params->tid;
5340 u16 *ssn = ¶ms->ssn;
5341
5342 wl1271_debug(DEBUG_MAC80211, "mac80211 ampdu action %d tid %d", action,
5343 tid);
5344
5345 /* sanity check - the fields in FW are only 8bits wide */
5346 if (WARN_ON(tid > 0xFF))
5347 return -ENOTSUPP;
5348
5349 mutex_lock(&wl->mutex);
5350
5351 if (unlikely(wl->state != WLCORE_STATE_ON)) {
5352 ret = -EAGAIN;
5353 goto out;
5354 }
5355
5356 if (wlvif->bss_type == BSS_TYPE_STA_BSS) {
5357 hlid = wlvif->sta.hlid;
5358 } else if (wlvif->bss_type == BSS_TYPE_AP_BSS) {
5359 struct wl1271_station *wl_sta;
5360
5361 wl_sta = (struct wl1271_station *)sta->drv_priv;
5362 hlid = wl_sta->hlid;
5363 } else {
5364 ret = -EINVAL;
5365 goto out;
5366 }
5367
5368 ba_bitmap = &wl->links[hlid].ba_bitmap;
5369
5370 ret = pm_runtime_get_sync(wl->dev);
5371 if (ret < 0) {
5372 pm_runtime_put_noidle(wl->dev);
5373 goto out;
5374 }
5375
5376 wl1271_debug(DEBUG_MAC80211, "mac80211 ampdu: Rx tid %d action %d",
5377 tid, action);
5378
5379 switch (action) {
5380 case IEEE80211_AMPDU_RX_START:
5381 if (!wlvif->ba_support || !wlvif->ba_allowed) {
5382 ret = -ENOTSUPP;
5383 break;
5384 }
5385
5386 if (wl->ba_rx_session_count >= wl->ba_rx_session_count_max) {
5387 ret = -EBUSY;
5388 wl1271_error("exceeded max RX BA sessions");
5389 break;
5390 }
5391
5392 if (*ba_bitmap & BIT(tid)) {
5393 ret = -EINVAL;
5394 wl1271_error("cannot enable RX BA session on active "
5395 "tid: %d", tid);
5396 break;
5397 }
5398
5399 ret = wl12xx_acx_set_ba_receiver_session(wl, tid, *ssn, true,
5400 hlid,
5401 params->buf_size);
5402
5403 if (!ret) {
5404 *ba_bitmap |= BIT(tid);
5405 wl->ba_rx_session_count++;
5406 }
5407 break;
5408
5409 case IEEE80211_AMPDU_RX_STOP:
5410 if (!(*ba_bitmap & BIT(tid))) {
5411 /*
5412 * this happens on reconfig - so only output a debug
5413 * message for now, and don't fail the function.
5414 */
5415 wl1271_debug(DEBUG_MAC80211,
5416 "no active RX BA session on tid: %d",
5417 tid);
5418 ret = 0;
5419 break;
5420 }
5421
5422 ret = wl12xx_acx_set_ba_receiver_session(wl, tid, 0, false,
5423 hlid, 0);
5424 if (!ret) {
5425 *ba_bitmap &= ~BIT(tid);
5426 wl->ba_rx_session_count--;
5427 }
5428 break;
5429
5430 /*
5431 * The BA initiator session management in FW independently.
5432 * Falling break here on purpose for all TX APDU commands.
5433 */
5434 case IEEE80211_AMPDU_TX_START:
5435 case IEEE80211_AMPDU_TX_STOP_CONT:
5436 case IEEE80211_AMPDU_TX_STOP_FLUSH:
5437 case IEEE80211_AMPDU_TX_STOP_FLUSH_CONT:
5438 case IEEE80211_AMPDU_TX_OPERATIONAL:
5439 ret = -EINVAL;
5440 break;
5441
5442 default:
5443 wl1271_error("Incorrect ampdu action id=%x\n", action);
5444 ret = -EINVAL;
5445 }
5446
5447 pm_runtime_mark_last_busy(wl->dev);
5448 pm_runtime_put_autosuspend(wl->dev);
5449
5450 out:
5451 mutex_unlock(&wl->mutex);
5452
5453 return ret;
5454 }
5455
wl12xx_set_bitrate_mask(struct ieee80211_hw * hw,struct ieee80211_vif * vif,const struct cfg80211_bitrate_mask * mask)5456 static int wl12xx_set_bitrate_mask(struct ieee80211_hw *hw,
5457 struct ieee80211_vif *vif,
5458 const struct cfg80211_bitrate_mask *mask)
5459 {
5460 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
5461 struct wl1271 *wl = hw->priv;
5462 int i, ret = 0;
5463
5464 wl1271_debug(DEBUG_MAC80211, "mac80211 set_bitrate_mask 0x%x 0x%x",
5465 mask->control[NL80211_BAND_2GHZ].legacy,
5466 mask->control[NL80211_BAND_5GHZ].legacy);
5467
5468 mutex_lock(&wl->mutex);
5469
5470 for (i = 0; i < WLCORE_NUM_BANDS; i++)
5471 wlvif->bitrate_masks[i] =
5472 wl1271_tx_enabled_rates_get(wl,
5473 mask->control[i].legacy,
5474 i);
5475
5476 if (unlikely(wl->state != WLCORE_STATE_ON))
5477 goto out;
5478
5479 if (wlvif->bss_type == BSS_TYPE_STA_BSS &&
5480 !test_bit(WLVIF_FLAG_STA_ASSOCIATED, &wlvif->flags)) {
5481
5482 ret = pm_runtime_get_sync(wl->dev);
5483 if (ret < 0) {
5484 pm_runtime_put_noidle(wl->dev);
5485 goto out;
5486 }
5487
5488 wl1271_set_band_rate(wl, wlvif);
5489 wlvif->basic_rate =
5490 wl1271_tx_min_rate_get(wl, wlvif->basic_rate_set);
5491 ret = wl1271_acx_sta_rate_policies(wl, wlvif);
5492
5493 pm_runtime_mark_last_busy(wl->dev);
5494 pm_runtime_put_autosuspend(wl->dev);
5495 }
5496 out:
5497 mutex_unlock(&wl->mutex);
5498
5499 return ret;
5500 }
5501
wl12xx_op_channel_switch(struct ieee80211_hw * hw,struct ieee80211_vif * vif,struct ieee80211_channel_switch * ch_switch)5502 static void wl12xx_op_channel_switch(struct ieee80211_hw *hw,
5503 struct ieee80211_vif *vif,
5504 struct ieee80211_channel_switch *ch_switch)
5505 {
5506 struct wl1271 *wl = hw->priv;
5507 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
5508 int ret;
5509
5510 wl1271_debug(DEBUG_MAC80211, "mac80211 channel switch");
5511
5512 wl1271_tx_flush(wl);
5513
5514 mutex_lock(&wl->mutex);
5515
5516 if (unlikely(wl->state == WLCORE_STATE_OFF)) {
5517 if (test_bit(WLVIF_FLAG_STA_ASSOCIATED, &wlvif->flags))
5518 ieee80211_chswitch_done(vif, false);
5519 goto out;
5520 } else if (unlikely(wl->state != WLCORE_STATE_ON)) {
5521 goto out;
5522 }
5523
5524 ret = pm_runtime_get_sync(wl->dev);
5525 if (ret < 0) {
5526 pm_runtime_put_noidle(wl->dev);
5527 goto out;
5528 }
5529
5530 /* TODO: change mac80211 to pass vif as param */
5531
5532 if (test_bit(WLVIF_FLAG_STA_ASSOCIATED, &wlvif->flags)) {
5533 unsigned long delay_usec;
5534
5535 ret = wl->ops->channel_switch(wl, wlvif, ch_switch);
5536 if (ret)
5537 goto out_sleep;
5538
5539 set_bit(WLVIF_FLAG_CS_PROGRESS, &wlvif->flags);
5540
5541 /* indicate failure 5 seconds after channel switch time */
5542 delay_usec = ieee80211_tu_to_usec(wlvif->beacon_int) *
5543 ch_switch->count;
5544 ieee80211_queue_delayed_work(hw, &wlvif->channel_switch_work,
5545 usecs_to_jiffies(delay_usec) +
5546 msecs_to_jiffies(5000));
5547 }
5548
5549 out_sleep:
5550 pm_runtime_mark_last_busy(wl->dev);
5551 pm_runtime_put_autosuspend(wl->dev);
5552
5553 out:
5554 mutex_unlock(&wl->mutex);
5555 }
5556
wlcore_get_beacon_ie(struct wl1271 * wl,struct wl12xx_vif * wlvif,u8 eid)5557 static const void *wlcore_get_beacon_ie(struct wl1271 *wl,
5558 struct wl12xx_vif *wlvif,
5559 u8 eid)
5560 {
5561 int ieoffset = offsetof(struct ieee80211_mgmt, u.beacon.variable);
5562 struct sk_buff *beacon =
5563 ieee80211_beacon_get(wl->hw, wl12xx_wlvif_to_vif(wlvif));
5564
5565 if (!beacon)
5566 return NULL;
5567
5568 return cfg80211_find_ie(eid,
5569 beacon->data + ieoffset,
5570 beacon->len - ieoffset);
5571 }
5572
wlcore_get_csa_count(struct wl1271 * wl,struct wl12xx_vif * wlvif,u8 * csa_count)5573 static int wlcore_get_csa_count(struct wl1271 *wl, struct wl12xx_vif *wlvif,
5574 u8 *csa_count)
5575 {
5576 const u8 *ie;
5577 const struct ieee80211_channel_sw_ie *ie_csa;
5578
5579 ie = wlcore_get_beacon_ie(wl, wlvif, WLAN_EID_CHANNEL_SWITCH);
5580 if (!ie)
5581 return -EINVAL;
5582
5583 ie_csa = (struct ieee80211_channel_sw_ie *)&ie[2];
5584 *csa_count = ie_csa->count;
5585
5586 return 0;
5587 }
5588
wlcore_op_channel_switch_beacon(struct ieee80211_hw * hw,struct ieee80211_vif * vif,struct cfg80211_chan_def * chandef)5589 static void wlcore_op_channel_switch_beacon(struct ieee80211_hw *hw,
5590 struct ieee80211_vif *vif,
5591 struct cfg80211_chan_def *chandef)
5592 {
5593 struct wl1271 *wl = hw->priv;
5594 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
5595 struct ieee80211_channel_switch ch_switch = {
5596 .block_tx = true,
5597 .chandef = *chandef,
5598 };
5599 int ret;
5600
5601 wl1271_debug(DEBUG_MAC80211,
5602 "mac80211 channel switch beacon (role %d)",
5603 wlvif->role_id);
5604
5605 ret = wlcore_get_csa_count(wl, wlvif, &ch_switch.count);
5606 if (ret < 0) {
5607 wl1271_error("error getting beacon (for CSA counter)");
5608 return;
5609 }
5610
5611 mutex_lock(&wl->mutex);
5612
5613 if (unlikely(wl->state != WLCORE_STATE_ON)) {
5614 ret = -EBUSY;
5615 goto out;
5616 }
5617
5618 ret = pm_runtime_get_sync(wl->dev);
5619 if (ret < 0) {
5620 pm_runtime_put_noidle(wl->dev);
5621 goto out;
5622 }
5623
5624 ret = wl->ops->channel_switch(wl, wlvif, &ch_switch);
5625 if (ret)
5626 goto out_sleep;
5627
5628 set_bit(WLVIF_FLAG_CS_PROGRESS, &wlvif->flags);
5629
5630 out_sleep:
5631 pm_runtime_mark_last_busy(wl->dev);
5632 pm_runtime_put_autosuspend(wl->dev);
5633 out:
5634 mutex_unlock(&wl->mutex);
5635 }
5636
wlcore_op_flush(struct ieee80211_hw * hw,struct ieee80211_vif * vif,u32 queues,bool drop)5637 static void wlcore_op_flush(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
5638 u32 queues, bool drop)
5639 {
5640 struct wl1271 *wl = hw->priv;
5641
5642 wl1271_tx_flush(wl);
5643 }
5644
wlcore_op_remain_on_channel(struct ieee80211_hw * hw,struct ieee80211_vif * vif,struct ieee80211_channel * chan,int duration,enum ieee80211_roc_type type)5645 static int wlcore_op_remain_on_channel(struct ieee80211_hw *hw,
5646 struct ieee80211_vif *vif,
5647 struct ieee80211_channel *chan,
5648 int duration,
5649 enum ieee80211_roc_type type)
5650 {
5651 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
5652 struct wl1271 *wl = hw->priv;
5653 int channel, active_roc, ret = 0;
5654
5655 channel = ieee80211_frequency_to_channel(chan->center_freq);
5656
5657 wl1271_debug(DEBUG_MAC80211, "mac80211 roc %d (%d)",
5658 channel, wlvif->role_id);
5659
5660 mutex_lock(&wl->mutex);
5661
5662 if (unlikely(wl->state != WLCORE_STATE_ON))
5663 goto out;
5664
5665 /* return EBUSY if we can't ROC right now */
5666 active_roc = find_first_bit(wl->roc_map, WL12XX_MAX_ROLES);
5667 if (wl->roc_vif || active_roc < WL12XX_MAX_ROLES) {
5668 wl1271_warning("active roc on role %d", active_roc);
5669 ret = -EBUSY;
5670 goto out;
5671 }
5672
5673 ret = pm_runtime_get_sync(wl->dev);
5674 if (ret < 0) {
5675 pm_runtime_put_noidle(wl->dev);
5676 goto out;
5677 }
5678
5679 ret = wl12xx_start_dev(wl, wlvif, chan->band, channel);
5680 if (ret < 0)
5681 goto out_sleep;
5682
5683 wl->roc_vif = vif;
5684 ieee80211_queue_delayed_work(hw, &wl->roc_complete_work,
5685 msecs_to_jiffies(duration));
5686 out_sleep:
5687 pm_runtime_mark_last_busy(wl->dev);
5688 pm_runtime_put_autosuspend(wl->dev);
5689 out:
5690 mutex_unlock(&wl->mutex);
5691 return ret;
5692 }
5693
__wlcore_roc_completed(struct wl1271 * wl)5694 static int __wlcore_roc_completed(struct wl1271 *wl)
5695 {
5696 struct wl12xx_vif *wlvif;
5697 int ret;
5698
5699 /* already completed */
5700 if (unlikely(!wl->roc_vif))
5701 return 0;
5702
5703 wlvif = wl12xx_vif_to_data(wl->roc_vif);
5704
5705 if (!test_bit(WLVIF_FLAG_INITIALIZED, &wlvif->flags))
5706 return -EBUSY;
5707
5708 ret = wl12xx_stop_dev(wl, wlvif);
5709 if (ret < 0)
5710 return ret;
5711
5712 wl->roc_vif = NULL;
5713
5714 return 0;
5715 }
5716
wlcore_roc_completed(struct wl1271 * wl)5717 static int wlcore_roc_completed(struct wl1271 *wl)
5718 {
5719 int ret;
5720
5721 wl1271_debug(DEBUG_MAC80211, "roc complete");
5722
5723 mutex_lock(&wl->mutex);
5724
5725 if (unlikely(wl->state != WLCORE_STATE_ON)) {
5726 ret = -EBUSY;
5727 goto out;
5728 }
5729
5730 ret = pm_runtime_get_sync(wl->dev);
5731 if (ret < 0) {
5732 pm_runtime_put_noidle(wl->dev);
5733 goto out;
5734 }
5735
5736 ret = __wlcore_roc_completed(wl);
5737
5738 pm_runtime_mark_last_busy(wl->dev);
5739 pm_runtime_put_autosuspend(wl->dev);
5740 out:
5741 mutex_unlock(&wl->mutex);
5742
5743 return ret;
5744 }
5745
wlcore_roc_complete_work(struct work_struct * work)5746 static void wlcore_roc_complete_work(struct work_struct *work)
5747 {
5748 struct delayed_work *dwork;
5749 struct wl1271 *wl;
5750 int ret;
5751
5752 dwork = to_delayed_work(work);
5753 wl = container_of(dwork, struct wl1271, roc_complete_work);
5754
5755 ret = wlcore_roc_completed(wl);
5756 if (!ret)
5757 ieee80211_remain_on_channel_expired(wl->hw);
5758 }
5759
wlcore_op_cancel_remain_on_channel(struct ieee80211_hw * hw)5760 static int wlcore_op_cancel_remain_on_channel(struct ieee80211_hw *hw)
5761 {
5762 struct wl1271 *wl = hw->priv;
5763
5764 wl1271_debug(DEBUG_MAC80211, "mac80211 croc");
5765
5766 /* TODO: per-vif */
5767 wl1271_tx_flush(wl);
5768
5769 /*
5770 * we can't just flush_work here, because it might deadlock
5771 * (as we might get called from the same workqueue)
5772 */
5773 cancel_delayed_work_sync(&wl->roc_complete_work);
5774 wlcore_roc_completed(wl);
5775
5776 return 0;
5777 }
5778
wlcore_op_sta_rc_update(struct ieee80211_hw * hw,struct ieee80211_vif * vif,struct ieee80211_sta * sta,u32 changed)5779 static void wlcore_op_sta_rc_update(struct ieee80211_hw *hw,
5780 struct ieee80211_vif *vif,
5781 struct ieee80211_sta *sta,
5782 u32 changed)
5783 {
5784 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
5785
5786 wl1271_debug(DEBUG_MAC80211, "mac80211 sta_rc_update");
5787
5788 if (!(changed & IEEE80211_RC_BW_CHANGED))
5789 return;
5790
5791 /* this callback is atomic, so schedule a new work */
5792 wlvif->rc_update_bw = sta->bandwidth;
5793 memcpy(&wlvif->rc_ht_cap, &sta->ht_cap, sizeof(sta->ht_cap));
5794 ieee80211_queue_work(hw, &wlvif->rc_update_work);
5795 }
5796
wlcore_op_sta_statistics(struct ieee80211_hw * hw,struct ieee80211_vif * vif,struct ieee80211_sta * sta,struct station_info * sinfo)5797 static void wlcore_op_sta_statistics(struct ieee80211_hw *hw,
5798 struct ieee80211_vif *vif,
5799 struct ieee80211_sta *sta,
5800 struct station_info *sinfo)
5801 {
5802 struct wl1271 *wl = hw->priv;
5803 struct wl12xx_vif *wlvif = wl12xx_vif_to_data(vif);
5804 s8 rssi_dbm;
5805 int ret;
5806
5807 wl1271_debug(DEBUG_MAC80211, "mac80211 get_rssi");
5808
5809 mutex_lock(&wl->mutex);
5810
5811 if (unlikely(wl->state != WLCORE_STATE_ON))
5812 goto out;
5813
5814 ret = pm_runtime_get_sync(wl->dev);
5815 if (ret < 0) {
5816 pm_runtime_put_noidle(wl->dev);
5817 goto out_sleep;
5818 }
5819
5820 ret = wlcore_acx_average_rssi(wl, wlvif, &rssi_dbm);
5821 if (ret < 0)
5822 goto out_sleep;
5823
5824 sinfo->filled |= BIT_ULL(NL80211_STA_INFO_SIGNAL);
5825 sinfo->signal = rssi_dbm;
5826
5827 out_sleep:
5828 pm_runtime_mark_last_busy(wl->dev);
5829 pm_runtime_put_autosuspend(wl->dev);
5830
5831 out:
5832 mutex_unlock(&wl->mutex);
5833 }
5834
wlcore_op_get_expected_throughput(struct ieee80211_hw * hw,struct ieee80211_sta * sta)5835 static u32 wlcore_op_get_expected_throughput(struct ieee80211_hw *hw,
5836 struct ieee80211_sta *sta)
5837 {
5838 struct wl1271_station *wl_sta = (struct wl1271_station *)sta->drv_priv;
5839 struct wl1271 *wl = hw->priv;
5840 u8 hlid = wl_sta->hlid;
5841
5842 /* return in units of Kbps */
5843 return (wl->links[hlid].fw_rate_mbps * 1000);
5844 }
5845
wl1271_tx_frames_pending(struct ieee80211_hw * hw)5846 static bool wl1271_tx_frames_pending(struct ieee80211_hw *hw)
5847 {
5848 struct wl1271 *wl = hw->priv;
5849 bool ret = false;
5850
5851 mutex_lock(&wl->mutex);
5852
5853 if (unlikely(wl->state != WLCORE_STATE_ON))
5854 goto out;
5855
5856 /* packets are considered pending if in the TX queue or the FW */
5857 ret = (wl1271_tx_total_queue_count(wl) > 0) || (wl->tx_frames_cnt > 0);
5858 out:
5859 mutex_unlock(&wl->mutex);
5860
5861 return ret;
5862 }
5863
5864 /* can't be const, mac80211 writes to this */
5865 static struct ieee80211_rate wl1271_rates[] = {
5866 { .bitrate = 10,
5867 .hw_value = CONF_HW_BIT_RATE_1MBPS,
5868 .hw_value_short = CONF_HW_BIT_RATE_1MBPS, },
5869 { .bitrate = 20,
5870 .hw_value = CONF_HW_BIT_RATE_2MBPS,
5871 .hw_value_short = CONF_HW_BIT_RATE_2MBPS,
5872 .flags = IEEE80211_RATE_SHORT_PREAMBLE },
5873 { .bitrate = 55,
5874 .hw_value = CONF_HW_BIT_RATE_5_5MBPS,
5875 .hw_value_short = CONF_HW_BIT_RATE_5_5MBPS,
5876 .flags = IEEE80211_RATE_SHORT_PREAMBLE },
5877 { .bitrate = 110,
5878 .hw_value = CONF_HW_BIT_RATE_11MBPS,
5879 .hw_value_short = CONF_HW_BIT_RATE_11MBPS,
5880 .flags = IEEE80211_RATE_SHORT_PREAMBLE },
5881 { .bitrate = 60,
5882 .hw_value = CONF_HW_BIT_RATE_6MBPS,
5883 .hw_value_short = CONF_HW_BIT_RATE_6MBPS, },
5884 { .bitrate = 90,
5885 .hw_value = CONF_HW_BIT_RATE_9MBPS,
5886 .hw_value_short = CONF_HW_BIT_RATE_9MBPS, },
5887 { .bitrate = 120,
5888 .hw_value = CONF_HW_BIT_RATE_12MBPS,
5889 .hw_value_short = CONF_HW_BIT_RATE_12MBPS, },
5890 { .bitrate = 180,
5891 .hw_value = CONF_HW_BIT_RATE_18MBPS,
5892 .hw_value_short = CONF_HW_BIT_RATE_18MBPS, },
5893 { .bitrate = 240,
5894 .hw_value = CONF_HW_BIT_RATE_24MBPS,
5895 .hw_value_short = CONF_HW_BIT_RATE_24MBPS, },
5896 { .bitrate = 360,
5897 .hw_value = CONF_HW_BIT_RATE_36MBPS,
5898 .hw_value_short = CONF_HW_BIT_RATE_36MBPS, },
5899 { .bitrate = 480,
5900 .hw_value = CONF_HW_BIT_RATE_48MBPS,
5901 .hw_value_short = CONF_HW_BIT_RATE_48MBPS, },
5902 { .bitrate = 540,
5903 .hw_value = CONF_HW_BIT_RATE_54MBPS,
5904 .hw_value_short = CONF_HW_BIT_RATE_54MBPS, },
5905 };
5906
5907 /* can't be const, mac80211 writes to this */
5908 static struct ieee80211_channel wl1271_channels[] = {
5909 { .hw_value = 1, .center_freq = 2412, .max_power = WLCORE_MAX_TXPWR },
5910 { .hw_value = 2, .center_freq = 2417, .max_power = WLCORE_MAX_TXPWR },
5911 { .hw_value = 3, .center_freq = 2422, .max_power = WLCORE_MAX_TXPWR },
5912 { .hw_value = 4, .center_freq = 2427, .max_power = WLCORE_MAX_TXPWR },
5913 { .hw_value = 5, .center_freq = 2432, .max_power = WLCORE_MAX_TXPWR },
5914 { .hw_value = 6, .center_freq = 2437, .max_power = WLCORE_MAX_TXPWR },
5915 { .hw_value = 7, .center_freq = 2442, .max_power = WLCORE_MAX_TXPWR },
5916 { .hw_value = 8, .center_freq = 2447, .max_power = WLCORE_MAX_TXPWR },
5917 { .hw_value = 9, .center_freq = 2452, .max_power = WLCORE_MAX_TXPWR },
5918 { .hw_value = 10, .center_freq = 2457, .max_power = WLCORE_MAX_TXPWR },
5919 { .hw_value = 11, .center_freq = 2462, .max_power = WLCORE_MAX_TXPWR },
5920 { .hw_value = 12, .center_freq = 2467, .max_power = WLCORE_MAX_TXPWR },
5921 { .hw_value = 13, .center_freq = 2472, .max_power = WLCORE_MAX_TXPWR },
5922 { .hw_value = 14, .center_freq = 2484, .max_power = WLCORE_MAX_TXPWR },
5923 };
5924
5925 /* can't be const, mac80211 writes to this */
5926 static struct ieee80211_supported_band wl1271_band_2ghz = {
5927 .channels = wl1271_channels,
5928 .n_channels = ARRAY_SIZE(wl1271_channels),
5929 .bitrates = wl1271_rates,
5930 .n_bitrates = ARRAY_SIZE(wl1271_rates),
5931 };
5932
5933 /* 5 GHz data rates for WL1273 */
5934 static struct ieee80211_rate wl1271_rates_5ghz[] = {
5935 { .bitrate = 60,
5936 .hw_value = CONF_HW_BIT_RATE_6MBPS,
5937 .hw_value_short = CONF_HW_BIT_RATE_6MBPS, },
5938 { .bitrate = 90,
5939 .hw_value = CONF_HW_BIT_RATE_9MBPS,
5940 .hw_value_short = CONF_HW_BIT_RATE_9MBPS, },
5941 { .bitrate = 120,
5942 .hw_value = CONF_HW_BIT_RATE_12MBPS,
5943 .hw_value_short = CONF_HW_BIT_RATE_12MBPS, },
5944 { .bitrate = 180,
5945 .hw_value = CONF_HW_BIT_RATE_18MBPS,
5946 .hw_value_short = CONF_HW_BIT_RATE_18MBPS, },
5947 { .bitrate = 240,
5948 .hw_value = CONF_HW_BIT_RATE_24MBPS,
5949 .hw_value_short = CONF_HW_BIT_RATE_24MBPS, },
5950 { .bitrate = 360,
5951 .hw_value = CONF_HW_BIT_RATE_36MBPS,
5952 .hw_value_short = CONF_HW_BIT_RATE_36MBPS, },
5953 { .bitrate = 480,
5954 .hw_value = CONF_HW_BIT_RATE_48MBPS,
5955 .hw_value_short = CONF_HW_BIT_RATE_48MBPS, },
5956 { .bitrate = 540,
5957 .hw_value = CONF_HW_BIT_RATE_54MBPS,
5958 .hw_value_short = CONF_HW_BIT_RATE_54MBPS, },
5959 };
5960
5961 /* 5 GHz band channels for WL1273 */
5962 static struct ieee80211_channel wl1271_channels_5ghz[] = {
5963 { .hw_value = 8, .center_freq = 5040, .max_power = WLCORE_MAX_TXPWR },
5964 { .hw_value = 12, .center_freq = 5060, .max_power = WLCORE_MAX_TXPWR },
5965 { .hw_value = 16, .center_freq = 5080, .max_power = WLCORE_MAX_TXPWR },
5966 { .hw_value = 34, .center_freq = 5170, .max_power = WLCORE_MAX_TXPWR },
5967 { .hw_value = 36, .center_freq = 5180, .max_power = WLCORE_MAX_TXPWR },
5968 { .hw_value = 38, .center_freq = 5190, .max_power = WLCORE_MAX_TXPWR },
5969 { .hw_value = 40, .center_freq = 5200, .max_power = WLCORE_MAX_TXPWR },
5970 { .hw_value = 42, .center_freq = 5210, .max_power = WLCORE_MAX_TXPWR },
5971 { .hw_value = 44, .center_freq = 5220, .max_power = WLCORE_MAX_TXPWR },
5972 { .hw_value = 46, .center_freq = 5230, .max_power = WLCORE_MAX_TXPWR },
5973 { .hw_value = 48, .center_freq = 5240, .max_power = WLCORE_MAX_TXPWR },
5974 { .hw_value = 52, .center_freq = 5260, .max_power = WLCORE_MAX_TXPWR },
5975 { .hw_value = 56, .center_freq = 5280, .max_power = WLCORE_MAX_TXPWR },
5976 { .hw_value = 60, .center_freq = 5300, .max_power = WLCORE_MAX_TXPWR },
5977 { .hw_value = 64, .center_freq = 5320, .max_power = WLCORE_MAX_TXPWR },
5978 { .hw_value = 100, .center_freq = 5500, .max_power = WLCORE_MAX_TXPWR },
5979 { .hw_value = 104, .center_freq = 5520, .max_power = WLCORE_MAX_TXPWR },
5980 { .hw_value = 108, .center_freq = 5540, .max_power = WLCORE_MAX_TXPWR },
5981 { .hw_value = 112, .center_freq = 5560, .max_power = WLCORE_MAX_TXPWR },
5982 { .hw_value = 116, .center_freq = 5580, .max_power = WLCORE_MAX_TXPWR },
5983 { .hw_value = 120, .center_freq = 5600, .max_power = WLCORE_MAX_TXPWR },
5984 { .hw_value = 124, .center_freq = 5620, .max_power = WLCORE_MAX_TXPWR },
5985 { .hw_value = 128, .center_freq = 5640, .max_power = WLCORE_MAX_TXPWR },
5986 { .hw_value = 132, .center_freq = 5660, .max_power = WLCORE_MAX_TXPWR },
5987 { .hw_value = 136, .center_freq = 5680, .max_power = WLCORE_MAX_TXPWR },
5988 { .hw_value = 140, .center_freq = 5700, .max_power = WLCORE_MAX_TXPWR },
5989 { .hw_value = 149, .center_freq = 5745, .max_power = WLCORE_MAX_TXPWR },
5990 { .hw_value = 153, .center_freq = 5765, .max_power = WLCORE_MAX_TXPWR },
5991 { .hw_value = 157, .center_freq = 5785, .max_power = WLCORE_MAX_TXPWR },
5992 { .hw_value = 161, .center_freq = 5805, .max_power = WLCORE_MAX_TXPWR },
5993 { .hw_value = 165, .center_freq = 5825, .max_power = WLCORE_MAX_TXPWR },
5994 };
5995
5996 static struct ieee80211_supported_band wl1271_band_5ghz = {
5997 .channels = wl1271_channels_5ghz,
5998 .n_channels = ARRAY_SIZE(wl1271_channels_5ghz),
5999 .bitrates = wl1271_rates_5ghz,
6000 .n_bitrates = ARRAY_SIZE(wl1271_rates_5ghz),
6001 };
6002
6003 static const struct ieee80211_ops wl1271_ops = {
6004 .start = wl1271_op_start,
6005 .stop = wlcore_op_stop,
6006 .add_interface = wl1271_op_add_interface,
6007 .remove_interface = wl1271_op_remove_interface,
6008 .change_interface = wl12xx_op_change_interface,
6009 #ifdef CONFIG_PM
6010 .suspend = wl1271_op_suspend,
6011 .resume = wl1271_op_resume,
6012 #endif
6013 .config = wl1271_op_config,
6014 .prepare_multicast = wl1271_op_prepare_multicast,
6015 .configure_filter = wl1271_op_configure_filter,
6016 .tx = wl1271_op_tx,
6017 .set_key = wlcore_op_set_key,
6018 .hw_scan = wl1271_op_hw_scan,
6019 .cancel_hw_scan = wl1271_op_cancel_hw_scan,
6020 .sched_scan_start = wl1271_op_sched_scan_start,
6021 .sched_scan_stop = wl1271_op_sched_scan_stop,
6022 .bss_info_changed = wl1271_op_bss_info_changed,
6023 .set_frag_threshold = wl1271_op_set_frag_threshold,
6024 .set_rts_threshold = wl1271_op_set_rts_threshold,
6025 .conf_tx = wl1271_op_conf_tx,
6026 .get_tsf = wl1271_op_get_tsf,
6027 .get_survey = wl1271_op_get_survey,
6028 .sta_state = wl12xx_op_sta_state,
6029 .ampdu_action = wl1271_op_ampdu_action,
6030 .tx_frames_pending = wl1271_tx_frames_pending,
6031 .set_bitrate_mask = wl12xx_set_bitrate_mask,
6032 .set_default_unicast_key = wl1271_op_set_default_key_idx,
6033 .channel_switch = wl12xx_op_channel_switch,
6034 .channel_switch_beacon = wlcore_op_channel_switch_beacon,
6035 .flush = wlcore_op_flush,
6036 .remain_on_channel = wlcore_op_remain_on_channel,
6037 .cancel_remain_on_channel = wlcore_op_cancel_remain_on_channel,
6038 .add_chanctx = wlcore_op_add_chanctx,
6039 .remove_chanctx = wlcore_op_remove_chanctx,
6040 .change_chanctx = wlcore_op_change_chanctx,
6041 .assign_vif_chanctx = wlcore_op_assign_vif_chanctx,
6042 .unassign_vif_chanctx = wlcore_op_unassign_vif_chanctx,
6043 .switch_vif_chanctx = wlcore_op_switch_vif_chanctx,
6044 .sta_rc_update = wlcore_op_sta_rc_update,
6045 .sta_statistics = wlcore_op_sta_statistics,
6046 .get_expected_throughput = wlcore_op_get_expected_throughput,
6047 CFG80211_TESTMODE_CMD(wl1271_tm_cmd)
6048 };
6049
6050
wlcore_rate_to_idx(struct wl1271 * wl,u8 rate,enum nl80211_band band)6051 u8 wlcore_rate_to_idx(struct wl1271 *wl, u8 rate, enum nl80211_band band)
6052 {
6053 u8 idx;
6054
6055 BUG_ON(band >= 2);
6056
6057 if (unlikely(rate >= wl->hw_tx_rate_tbl_size)) {
6058 wl1271_error("Illegal RX rate from HW: %d", rate);
6059 return 0;
6060 }
6061
6062 idx = wl->band_rate_to_idx[band][rate];
6063 if (unlikely(idx == CONF_HW_RXTX_RATE_UNSUPPORTED)) {
6064 wl1271_error("Unsupported RX rate from HW: %d", rate);
6065 return 0;
6066 }
6067
6068 return idx;
6069 }
6070
wl12xx_derive_mac_addresses(struct wl1271 * wl,u32 oui,u32 nic)6071 static void wl12xx_derive_mac_addresses(struct wl1271 *wl, u32 oui, u32 nic)
6072 {
6073 int i;
6074
6075 wl1271_debug(DEBUG_PROBE, "base address: oui %06x nic %06x",
6076 oui, nic);
6077
6078 if (nic + WLCORE_NUM_MAC_ADDRESSES - wl->num_mac_addr > 0xffffff)
6079 wl1271_warning("NIC part of the MAC address wraps around!");
6080
6081 for (i = 0; i < wl->num_mac_addr; i++) {
6082 wl->addresses[i].addr[0] = (u8)(oui >> 16);
6083 wl->addresses[i].addr[1] = (u8)(oui >> 8);
6084 wl->addresses[i].addr[2] = (u8) oui;
6085 wl->addresses[i].addr[3] = (u8)(nic >> 16);
6086 wl->addresses[i].addr[4] = (u8)(nic >> 8);
6087 wl->addresses[i].addr[5] = (u8) nic;
6088 nic++;
6089 }
6090
6091 /* we may be one address short at the most */
6092 WARN_ON(wl->num_mac_addr + 1 < WLCORE_NUM_MAC_ADDRESSES);
6093
6094 /*
6095 * turn on the LAA bit in the first address and use it as
6096 * the last address.
6097 */
6098 if (wl->num_mac_addr < WLCORE_NUM_MAC_ADDRESSES) {
6099 int idx = WLCORE_NUM_MAC_ADDRESSES - 1;
6100 memcpy(&wl->addresses[idx], &wl->addresses[0],
6101 sizeof(wl->addresses[0]));
6102 /* LAA bit */
6103 wl->addresses[idx].addr[0] |= BIT(1);
6104 }
6105
6106 wl->hw->wiphy->n_addresses = WLCORE_NUM_MAC_ADDRESSES;
6107 wl->hw->wiphy->addresses = wl->addresses;
6108 }
6109
wl12xx_get_hw_info(struct wl1271 * wl)6110 static int wl12xx_get_hw_info(struct wl1271 *wl)
6111 {
6112 int ret;
6113
6114 ret = wlcore_read_reg(wl, REG_CHIP_ID_B, &wl->chip.id);
6115 if (ret < 0)
6116 goto out;
6117
6118 wl->fuse_oui_addr = 0;
6119 wl->fuse_nic_addr = 0;
6120
6121 ret = wl->ops->get_pg_ver(wl, &wl->hw_pg_ver);
6122 if (ret < 0)
6123 goto out;
6124
6125 if (wl->ops->get_mac)
6126 ret = wl->ops->get_mac(wl);
6127
6128 out:
6129 return ret;
6130 }
6131
wl1271_register_hw(struct wl1271 * wl)6132 static int wl1271_register_hw(struct wl1271 *wl)
6133 {
6134 int ret;
6135 u32 oui_addr = 0, nic_addr = 0;
6136 struct platform_device *pdev = wl->pdev;
6137 struct wlcore_platdev_data *pdev_data = dev_get_platdata(&pdev->dev);
6138
6139 if (wl->mac80211_registered)
6140 return 0;
6141
6142 if (wl->nvs_len >= 12) {
6143 /* NOTE: The wl->nvs->nvs element must be first, in
6144 * order to simplify the casting, we assume it is at
6145 * the beginning of the wl->nvs structure.
6146 */
6147 u8 *nvs_ptr = (u8 *)wl->nvs;
6148
6149 oui_addr =
6150 (nvs_ptr[11] << 16) + (nvs_ptr[10] << 8) + nvs_ptr[6];
6151 nic_addr =
6152 (nvs_ptr[5] << 16) + (nvs_ptr[4] << 8) + nvs_ptr[3];
6153 }
6154
6155 /* if the MAC address is zeroed in the NVS derive from fuse */
6156 if (oui_addr == 0 && nic_addr == 0) {
6157 oui_addr = wl->fuse_oui_addr;
6158 /* fuse has the BD_ADDR, the WLAN addresses are the next two */
6159 nic_addr = wl->fuse_nic_addr + 1;
6160 }
6161
6162 if (oui_addr == 0xdeadbe && nic_addr == 0xef0000) {
6163 wl1271_warning("Detected unconfigured mac address in nvs, derive from fuse instead.");
6164 if (!strcmp(pdev_data->family->name, "wl18xx")) {
6165 wl1271_warning("This default nvs file can be removed from the file system");
6166 } else {
6167 wl1271_warning("Your device performance is not optimized.");
6168 wl1271_warning("Please use the calibrator tool to configure your device.");
6169 }
6170
6171 if (wl->fuse_oui_addr == 0 && wl->fuse_nic_addr == 0) {
6172 wl1271_warning("Fuse mac address is zero. using random mac");
6173 /* Use TI oui and a random nic */
6174 oui_addr = WLCORE_TI_OUI_ADDRESS;
6175 nic_addr = get_random_int();
6176 } else {
6177 oui_addr = wl->fuse_oui_addr;
6178 /* fuse has the BD_ADDR, the WLAN addresses are the next two */
6179 nic_addr = wl->fuse_nic_addr + 1;
6180 }
6181 }
6182
6183 wl12xx_derive_mac_addresses(wl, oui_addr, nic_addr);
6184
6185 ret = ieee80211_register_hw(wl->hw);
6186 if (ret < 0) {
6187 wl1271_error("unable to register mac80211 hw: %d", ret);
6188 goto out;
6189 }
6190
6191 wl->mac80211_registered = true;
6192
6193 wl1271_debugfs_init(wl);
6194
6195 wl1271_notice("loaded");
6196
6197 out:
6198 return ret;
6199 }
6200
wl1271_unregister_hw(struct wl1271 * wl)6201 static void wl1271_unregister_hw(struct wl1271 *wl)
6202 {
6203 if (wl->plt)
6204 wl1271_plt_stop(wl);
6205
6206 ieee80211_unregister_hw(wl->hw);
6207 wl->mac80211_registered = false;
6208
6209 }
6210
wl1271_init_ieee80211(struct wl1271 * wl)6211 static int wl1271_init_ieee80211(struct wl1271 *wl)
6212 {
6213 int i;
6214 static const u32 cipher_suites[] = {
6215 WLAN_CIPHER_SUITE_WEP40,
6216 WLAN_CIPHER_SUITE_WEP104,
6217 WLAN_CIPHER_SUITE_TKIP,
6218 WLAN_CIPHER_SUITE_CCMP,
6219 WL1271_CIPHER_SUITE_GEM,
6220 };
6221
6222 /* The tx descriptor buffer */
6223 wl->hw->extra_tx_headroom = sizeof(struct wl1271_tx_hw_descr);
6224
6225 if (wl->quirks & WLCORE_QUIRK_TKIP_HEADER_SPACE)
6226 wl->hw->extra_tx_headroom += WL1271_EXTRA_SPACE_TKIP;
6227
6228 /* unit us */
6229 /* FIXME: find a proper value */
6230 wl->hw->max_listen_interval = wl->conf.conn.max_listen_interval;
6231
6232 ieee80211_hw_set(wl->hw, SUPPORT_FAST_XMIT);
6233 ieee80211_hw_set(wl->hw, CHANCTX_STA_CSA);
6234 ieee80211_hw_set(wl->hw, QUEUE_CONTROL);
6235 ieee80211_hw_set(wl->hw, TX_AMPDU_SETUP_IN_HW);
6236 ieee80211_hw_set(wl->hw, AMPDU_AGGREGATION);
6237 ieee80211_hw_set(wl->hw, AP_LINK_PS);
6238 ieee80211_hw_set(wl->hw, SPECTRUM_MGMT);
6239 ieee80211_hw_set(wl->hw, REPORTS_TX_ACK_STATUS);
6240 ieee80211_hw_set(wl->hw, CONNECTION_MONITOR);
6241 ieee80211_hw_set(wl->hw, HAS_RATE_CONTROL);
6242 ieee80211_hw_set(wl->hw, SUPPORTS_DYNAMIC_PS);
6243 ieee80211_hw_set(wl->hw, SIGNAL_DBM);
6244 ieee80211_hw_set(wl->hw, SUPPORTS_PS);
6245 ieee80211_hw_set(wl->hw, SUPPORTS_TX_FRAG);
6246
6247 wl->hw->wiphy->cipher_suites = cipher_suites;
6248 wl->hw->wiphy->n_cipher_suites = ARRAY_SIZE(cipher_suites);
6249
6250 wl->hw->wiphy->interface_modes = BIT(NL80211_IFTYPE_STATION) |
6251 BIT(NL80211_IFTYPE_AP) |
6252 BIT(NL80211_IFTYPE_P2P_DEVICE) |
6253 BIT(NL80211_IFTYPE_P2P_CLIENT) |
6254 #ifdef CONFIG_MAC80211_MESH
6255 BIT(NL80211_IFTYPE_MESH_POINT) |
6256 #endif
6257 BIT(NL80211_IFTYPE_P2P_GO);
6258
6259 wl->hw->wiphy->max_scan_ssids = 1;
6260 wl->hw->wiphy->max_sched_scan_ssids = 16;
6261 wl->hw->wiphy->max_match_sets = 16;
6262 /*
6263 * Maximum length of elements in scanning probe request templates
6264 * should be the maximum length possible for a template, without
6265 * the IEEE80211 header of the template
6266 */
6267 wl->hw->wiphy->max_scan_ie_len = WL1271_CMD_TEMPL_MAX_SIZE -
6268 sizeof(struct ieee80211_header);
6269
6270 wl->hw->wiphy->max_sched_scan_reqs = 1;
6271 wl->hw->wiphy->max_sched_scan_ie_len = WL1271_CMD_TEMPL_MAX_SIZE -
6272 sizeof(struct ieee80211_header);
6273
6274 wl->hw->wiphy->max_remain_on_channel_duration = 30000;
6275
6276 wl->hw->wiphy->flags |= WIPHY_FLAG_AP_UAPSD |
6277 WIPHY_FLAG_HAS_REMAIN_ON_CHANNEL |
6278 WIPHY_FLAG_HAS_CHANNEL_SWITCH;
6279
6280 wl->hw->wiphy->features |= NL80211_FEATURE_AP_SCAN;
6281
6282 /* make sure all our channels fit in the scanned_ch bitmask */
6283 BUILD_BUG_ON(ARRAY_SIZE(wl1271_channels) +
6284 ARRAY_SIZE(wl1271_channels_5ghz) >
6285 WL1271_MAX_CHANNELS);
6286 /*
6287 * clear channel flags from the previous usage
6288 * and restore max_power & max_antenna_gain values.
6289 */
6290 for (i = 0; i < ARRAY_SIZE(wl1271_channels); i++) {
6291 wl1271_band_2ghz.channels[i].flags = 0;
6292 wl1271_band_2ghz.channels[i].max_power = WLCORE_MAX_TXPWR;
6293 wl1271_band_2ghz.channels[i].max_antenna_gain = 0;
6294 }
6295
6296 for (i = 0; i < ARRAY_SIZE(wl1271_channels_5ghz); i++) {
6297 wl1271_band_5ghz.channels[i].flags = 0;
6298 wl1271_band_5ghz.channels[i].max_power = WLCORE_MAX_TXPWR;
6299 wl1271_band_5ghz.channels[i].max_antenna_gain = 0;
6300 }
6301
6302 /*
6303 * We keep local copies of the band structs because we need to
6304 * modify them on a per-device basis.
6305 */
6306 memcpy(&wl->bands[NL80211_BAND_2GHZ], &wl1271_band_2ghz,
6307 sizeof(wl1271_band_2ghz));
6308 memcpy(&wl->bands[NL80211_BAND_2GHZ].ht_cap,
6309 &wl->ht_cap[NL80211_BAND_2GHZ],
6310 sizeof(*wl->ht_cap));
6311 memcpy(&wl->bands[NL80211_BAND_5GHZ], &wl1271_band_5ghz,
6312 sizeof(wl1271_band_5ghz));
6313 memcpy(&wl->bands[NL80211_BAND_5GHZ].ht_cap,
6314 &wl->ht_cap[NL80211_BAND_5GHZ],
6315 sizeof(*wl->ht_cap));
6316
6317 wl->hw->wiphy->bands[NL80211_BAND_2GHZ] =
6318 &wl->bands[NL80211_BAND_2GHZ];
6319 wl->hw->wiphy->bands[NL80211_BAND_5GHZ] =
6320 &wl->bands[NL80211_BAND_5GHZ];
6321
6322 /*
6323 * allow 4 queues per mac address we support +
6324 * 1 cab queue per mac + one global offchannel Tx queue
6325 */
6326 wl->hw->queues = (NUM_TX_QUEUES + 1) * WLCORE_NUM_MAC_ADDRESSES + 1;
6327
6328 /* the last queue is the offchannel queue */
6329 wl->hw->offchannel_tx_hw_queue = wl->hw->queues - 1;
6330 wl->hw->max_rates = 1;
6331
6332 wl->hw->wiphy->reg_notifier = wl1271_reg_notify;
6333
6334 /* the FW answers probe-requests in AP-mode */
6335 wl->hw->wiphy->flags |= WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD;
6336 wl->hw->wiphy->probe_resp_offload =
6337 NL80211_PROBE_RESP_OFFLOAD_SUPPORT_WPS |
6338 NL80211_PROBE_RESP_OFFLOAD_SUPPORT_WPS2 |
6339 NL80211_PROBE_RESP_OFFLOAD_SUPPORT_P2P;
6340
6341 /* allowed interface combinations */
6342 wl->hw->wiphy->iface_combinations = wl->iface_combinations;
6343 wl->hw->wiphy->n_iface_combinations = wl->n_iface_combinations;
6344
6345 /* register vendor commands */
6346 wlcore_set_vendor_commands(wl->hw->wiphy);
6347
6348 SET_IEEE80211_DEV(wl->hw, wl->dev);
6349
6350 wl->hw->sta_data_size = sizeof(struct wl1271_station);
6351 wl->hw->vif_data_size = sizeof(struct wl12xx_vif);
6352
6353 wl->hw->max_rx_aggregation_subframes = wl->conf.ht.rx_ba_win_size;
6354
6355 return 0;
6356 }
6357
wlcore_alloc_hw(size_t priv_size,u32 aggr_buf_size,u32 mbox_size)6358 struct ieee80211_hw *wlcore_alloc_hw(size_t priv_size, u32 aggr_buf_size,
6359 u32 mbox_size)
6360 {
6361 struct ieee80211_hw *hw;
6362 struct wl1271 *wl;
6363 int i, j, ret;
6364 unsigned int order;
6365
6366 hw = ieee80211_alloc_hw(sizeof(*wl), &wl1271_ops);
6367 if (!hw) {
6368 wl1271_error("could not alloc ieee80211_hw");
6369 ret = -ENOMEM;
6370 goto err_hw_alloc;
6371 }
6372
6373 wl = hw->priv;
6374 memset(wl, 0, sizeof(*wl));
6375
6376 wl->priv = kzalloc(priv_size, GFP_KERNEL);
6377 if (!wl->priv) {
6378 wl1271_error("could not alloc wl priv");
6379 ret = -ENOMEM;
6380 goto err_priv_alloc;
6381 }
6382
6383 INIT_LIST_HEAD(&wl->wlvif_list);
6384
6385 wl->hw = hw;
6386
6387 /*
6388 * wl->num_links is not configured yet, so just use WLCORE_MAX_LINKS.
6389 * we don't allocate any additional resource here, so that's fine.
6390 */
6391 for (i = 0; i < NUM_TX_QUEUES; i++)
6392 for (j = 0; j < WLCORE_MAX_LINKS; j++)
6393 skb_queue_head_init(&wl->links[j].tx_queue[i]);
6394
6395 skb_queue_head_init(&wl->deferred_rx_queue);
6396 skb_queue_head_init(&wl->deferred_tx_queue);
6397
6398 INIT_WORK(&wl->netstack_work, wl1271_netstack_work);
6399 INIT_WORK(&wl->tx_work, wl1271_tx_work);
6400 INIT_WORK(&wl->recovery_work, wl1271_recovery_work);
6401 INIT_DELAYED_WORK(&wl->scan_complete_work, wl1271_scan_complete_work);
6402 INIT_DELAYED_WORK(&wl->roc_complete_work, wlcore_roc_complete_work);
6403 INIT_DELAYED_WORK(&wl->tx_watchdog_work, wl12xx_tx_watchdog_work);
6404
6405 wl->freezable_wq = create_freezable_workqueue("wl12xx_wq");
6406 if (!wl->freezable_wq) {
6407 ret = -ENOMEM;
6408 goto err_hw;
6409 }
6410
6411 wl->channel = 0;
6412 wl->rx_counter = 0;
6413 wl->power_level = WL1271_DEFAULT_POWER_LEVEL;
6414 wl->band = NL80211_BAND_2GHZ;
6415 wl->channel_type = NL80211_CHAN_NO_HT;
6416 wl->flags = 0;
6417 wl->sg_enabled = true;
6418 wl->sleep_auth = WL1271_PSM_ILLEGAL;
6419 wl->recovery_count = 0;
6420 wl->hw_pg_ver = -1;
6421 wl->ap_ps_map = 0;
6422 wl->ap_fw_ps_map = 0;
6423 wl->quirks = 0;
6424 wl->system_hlid = WL12XX_SYSTEM_HLID;
6425 wl->active_sta_count = 0;
6426 wl->active_link_count = 0;
6427 wl->fwlog_size = 0;
6428
6429 /* The system link is always allocated */
6430 __set_bit(WL12XX_SYSTEM_HLID, wl->links_map);
6431
6432 memset(wl->tx_frames_map, 0, sizeof(wl->tx_frames_map));
6433 for (i = 0; i < wl->num_tx_desc; i++)
6434 wl->tx_frames[i] = NULL;
6435
6436 spin_lock_init(&wl->wl_lock);
6437
6438 wl->state = WLCORE_STATE_OFF;
6439 wl->fw_type = WL12XX_FW_TYPE_NONE;
6440 mutex_init(&wl->mutex);
6441 mutex_init(&wl->flush_mutex);
6442 init_completion(&wl->nvs_loading_complete);
6443
6444 order = get_order(aggr_buf_size);
6445 wl->aggr_buf = (u8 *)__get_free_pages(GFP_KERNEL, order);
6446 if (!wl->aggr_buf) {
6447 ret = -ENOMEM;
6448 goto err_wq;
6449 }
6450 wl->aggr_buf_size = aggr_buf_size;
6451
6452 wl->dummy_packet = wl12xx_alloc_dummy_packet(wl);
6453 if (!wl->dummy_packet) {
6454 ret = -ENOMEM;
6455 goto err_aggr;
6456 }
6457
6458 /* Allocate one page for the FW log */
6459 wl->fwlog = (u8 *)get_zeroed_page(GFP_KERNEL);
6460 if (!wl->fwlog) {
6461 ret = -ENOMEM;
6462 goto err_dummy_packet;
6463 }
6464
6465 wl->mbox_size = mbox_size;
6466 wl->mbox = kmalloc(wl->mbox_size, GFP_KERNEL | GFP_DMA);
6467 if (!wl->mbox) {
6468 ret = -ENOMEM;
6469 goto err_fwlog;
6470 }
6471
6472 wl->buffer_32 = kmalloc(sizeof(*wl->buffer_32), GFP_KERNEL);
6473 if (!wl->buffer_32) {
6474 ret = -ENOMEM;
6475 goto err_mbox;
6476 }
6477
6478 return hw;
6479
6480 err_mbox:
6481 kfree(wl->mbox);
6482
6483 err_fwlog:
6484 free_page((unsigned long)wl->fwlog);
6485
6486 err_dummy_packet:
6487 dev_kfree_skb(wl->dummy_packet);
6488
6489 err_aggr:
6490 free_pages((unsigned long)wl->aggr_buf, order);
6491
6492 err_wq:
6493 destroy_workqueue(wl->freezable_wq);
6494
6495 err_hw:
6496 wl1271_debugfs_exit(wl);
6497 kfree(wl->priv);
6498
6499 err_priv_alloc:
6500 ieee80211_free_hw(hw);
6501
6502 err_hw_alloc:
6503
6504 return ERR_PTR(ret);
6505 }
6506 EXPORT_SYMBOL_GPL(wlcore_alloc_hw);
6507
wlcore_free_hw(struct wl1271 * wl)6508 int wlcore_free_hw(struct wl1271 *wl)
6509 {
6510 /* Unblock any fwlog readers */
6511 mutex_lock(&wl->mutex);
6512 wl->fwlog_size = -1;
6513 mutex_unlock(&wl->mutex);
6514
6515 wlcore_sysfs_free(wl);
6516
6517 kfree(wl->buffer_32);
6518 kfree(wl->mbox);
6519 free_page((unsigned long)wl->fwlog);
6520 dev_kfree_skb(wl->dummy_packet);
6521 free_pages((unsigned long)wl->aggr_buf, get_order(wl->aggr_buf_size));
6522
6523 wl1271_debugfs_exit(wl);
6524
6525 vfree(wl->fw);
6526 wl->fw = NULL;
6527 wl->fw_type = WL12XX_FW_TYPE_NONE;
6528 kfree(wl->nvs);
6529 wl->nvs = NULL;
6530
6531 kfree(wl->raw_fw_status);
6532 kfree(wl->fw_status);
6533 kfree(wl->tx_res_if);
6534 destroy_workqueue(wl->freezable_wq);
6535
6536 kfree(wl->priv);
6537 ieee80211_free_hw(wl->hw);
6538
6539 return 0;
6540 }
6541 EXPORT_SYMBOL_GPL(wlcore_free_hw);
6542
6543 #ifdef CONFIG_PM
6544 static const struct wiphy_wowlan_support wlcore_wowlan_support = {
6545 .flags = WIPHY_WOWLAN_ANY,
6546 .n_patterns = WL1271_MAX_RX_FILTERS,
6547 .pattern_min_len = 1,
6548 .pattern_max_len = WL1271_RX_FILTER_MAX_PATTERN_SIZE,
6549 };
6550 #endif
6551
wlcore_hardirq(int irq,void * cookie)6552 static irqreturn_t wlcore_hardirq(int irq, void *cookie)
6553 {
6554 return IRQ_WAKE_THREAD;
6555 }
6556
wlcore_nvs_cb(const struct firmware * fw,void * context)6557 static void wlcore_nvs_cb(const struct firmware *fw, void *context)
6558 {
6559 struct wl1271 *wl = context;
6560 struct platform_device *pdev = wl->pdev;
6561 struct wlcore_platdev_data *pdev_data = dev_get_platdata(&pdev->dev);
6562 struct resource *res;
6563
6564 int ret;
6565 irq_handler_t hardirq_fn = NULL;
6566
6567 if (fw) {
6568 wl->nvs = kmemdup(fw->data, fw->size, GFP_KERNEL);
6569 if (!wl->nvs) {
6570 wl1271_error("Could not allocate nvs data");
6571 goto out;
6572 }
6573 wl->nvs_len = fw->size;
6574 } else if (pdev_data->family->nvs_name) {
6575 wl1271_debug(DEBUG_BOOT, "Could not get nvs file %s",
6576 pdev_data->family->nvs_name);
6577 wl->nvs = NULL;
6578 wl->nvs_len = 0;
6579 } else {
6580 wl->nvs = NULL;
6581 wl->nvs_len = 0;
6582 }
6583
6584 ret = wl->ops->setup(wl);
6585 if (ret < 0)
6586 goto out_free_nvs;
6587
6588 BUG_ON(wl->num_tx_desc > WLCORE_MAX_TX_DESCRIPTORS);
6589
6590 /* adjust some runtime configuration parameters */
6591 wlcore_adjust_conf(wl);
6592
6593 res = platform_get_resource(pdev, IORESOURCE_IRQ, 0);
6594 if (!res) {
6595 wl1271_error("Could not get IRQ resource");
6596 goto out_free_nvs;
6597 }
6598
6599 wl->irq = res->start;
6600 wl->irq_flags = res->flags & IRQF_TRIGGER_MASK;
6601 wl->if_ops = pdev_data->if_ops;
6602
6603 if (wl->irq_flags & (IRQF_TRIGGER_RISING | IRQF_TRIGGER_FALLING))
6604 hardirq_fn = wlcore_hardirq;
6605 else
6606 wl->irq_flags |= IRQF_ONESHOT;
6607
6608 ret = wl12xx_set_power_on(wl);
6609 if (ret < 0)
6610 goto out_free_nvs;
6611
6612 ret = wl12xx_get_hw_info(wl);
6613 if (ret < 0) {
6614 wl1271_error("couldn't get hw info");
6615 wl1271_power_off(wl);
6616 goto out_free_nvs;
6617 }
6618
6619 ret = request_threaded_irq(wl->irq, hardirq_fn, wlcore_irq,
6620 wl->irq_flags, pdev->name, wl);
6621 if (ret < 0) {
6622 wl1271_error("interrupt configuration failed");
6623 wl1271_power_off(wl);
6624 goto out_free_nvs;
6625 }
6626
6627 #ifdef CONFIG_PM
6628 ret = enable_irq_wake(wl->irq);
6629 if (!ret) {
6630 wl->irq_wake_enabled = true;
6631 device_init_wakeup(wl->dev, 1);
6632 if (pdev_data->pwr_in_suspend)
6633 wl->hw->wiphy->wowlan = &wlcore_wowlan_support;
6634 }
6635 #endif
6636 disable_irq(wl->irq);
6637 wl1271_power_off(wl);
6638
6639 ret = wl->ops->identify_chip(wl);
6640 if (ret < 0)
6641 goto out_irq;
6642
6643 ret = wl1271_init_ieee80211(wl);
6644 if (ret)
6645 goto out_irq;
6646
6647 ret = wl1271_register_hw(wl);
6648 if (ret)
6649 goto out_irq;
6650
6651 ret = wlcore_sysfs_init(wl);
6652 if (ret)
6653 goto out_unreg;
6654
6655 wl->initialized = true;
6656 goto out;
6657
6658 out_unreg:
6659 wl1271_unregister_hw(wl);
6660
6661 out_irq:
6662 free_irq(wl->irq, wl);
6663
6664 out_free_nvs:
6665 kfree(wl->nvs);
6666
6667 out:
6668 release_firmware(fw);
6669 complete_all(&wl->nvs_loading_complete);
6670 }
6671
wlcore_runtime_suspend(struct device * dev)6672 static int __maybe_unused wlcore_runtime_suspend(struct device *dev)
6673 {
6674 struct wl1271 *wl = dev_get_drvdata(dev);
6675 struct wl12xx_vif *wlvif;
6676 int error;
6677
6678 /* We do not enter elp sleep in PLT mode */
6679 if (wl->plt)
6680 return 0;
6681
6682 /* Nothing to do if no ELP mode requested */
6683 if (wl->sleep_auth != WL1271_PSM_ELP)
6684 return 0;
6685
6686 wl12xx_for_each_wlvif(wl, wlvif) {
6687 if (!test_bit(WLVIF_FLAG_IN_PS, &wlvif->flags) &&
6688 test_bit(WLVIF_FLAG_IN_USE, &wlvif->flags))
6689 return -EBUSY;
6690 }
6691
6692 wl1271_debug(DEBUG_PSM, "chip to elp");
6693 error = wlcore_raw_write32(wl, HW_ACCESS_ELP_CTRL_REG, ELPCTRL_SLEEP);
6694 if (error < 0) {
6695 wl12xx_queue_recovery_work(wl);
6696
6697 return error;
6698 }
6699
6700 set_bit(WL1271_FLAG_IN_ELP, &wl->flags);
6701
6702 return 0;
6703 }
6704
wlcore_runtime_resume(struct device * dev)6705 static int __maybe_unused wlcore_runtime_resume(struct device *dev)
6706 {
6707 struct wl1271 *wl = dev_get_drvdata(dev);
6708 DECLARE_COMPLETION_ONSTACK(compl);
6709 unsigned long flags;
6710 int ret;
6711 unsigned long start_time = jiffies;
6712 bool pending = false;
6713
6714 /* Nothing to do if no ELP mode requested */
6715 if (!test_bit(WL1271_FLAG_IN_ELP, &wl->flags))
6716 return 0;
6717
6718 wl1271_debug(DEBUG_PSM, "waking up chip from elp");
6719
6720 spin_lock_irqsave(&wl->wl_lock, flags);
6721 if (test_bit(WL1271_FLAG_IRQ_RUNNING, &wl->flags))
6722 pending = true;
6723 else
6724 wl->elp_compl = &compl;
6725 spin_unlock_irqrestore(&wl->wl_lock, flags);
6726
6727 ret = wlcore_raw_write32(wl, HW_ACCESS_ELP_CTRL_REG, ELPCTRL_WAKE_UP);
6728 if (ret < 0) {
6729 wl12xx_queue_recovery_work(wl);
6730 goto err;
6731 }
6732
6733 if (!pending) {
6734 ret = wait_for_completion_timeout(&compl,
6735 msecs_to_jiffies(WL1271_WAKEUP_TIMEOUT));
6736 if (ret == 0) {
6737 wl1271_error("ELP wakeup timeout!");
6738 wl12xx_queue_recovery_work(wl);
6739
6740 /* Return no error for runtime PM for recovery */
6741 return 0;
6742 }
6743 }
6744
6745 clear_bit(WL1271_FLAG_IN_ELP, &wl->flags);
6746
6747 wl1271_debug(DEBUG_PSM, "wakeup time: %u ms",
6748 jiffies_to_msecs(jiffies - start_time));
6749
6750 return 0;
6751
6752 err:
6753 spin_lock_irqsave(&wl->wl_lock, flags);
6754 wl->elp_compl = NULL;
6755 spin_unlock_irqrestore(&wl->wl_lock, flags);
6756 return ret;
6757 }
6758
6759 static const struct dev_pm_ops wlcore_pm_ops = {
6760 SET_RUNTIME_PM_OPS(wlcore_runtime_suspend,
6761 wlcore_runtime_resume,
6762 NULL)
6763 };
6764
wlcore_probe(struct wl1271 * wl,struct platform_device * pdev)6765 int wlcore_probe(struct wl1271 *wl, struct platform_device *pdev)
6766 {
6767 struct wlcore_platdev_data *pdev_data = dev_get_platdata(&pdev->dev);
6768 const char *nvs_name;
6769 int ret = 0;
6770
6771 if (!wl->ops || !wl->ptable || !pdev_data)
6772 return -EINVAL;
6773
6774 wl->dev = &pdev->dev;
6775 wl->pdev = pdev;
6776 platform_set_drvdata(pdev, wl);
6777
6778 if (pdev_data->family && pdev_data->family->nvs_name) {
6779 nvs_name = pdev_data->family->nvs_name;
6780 ret = request_firmware_nowait(THIS_MODULE, FW_ACTION_HOTPLUG,
6781 nvs_name, &pdev->dev, GFP_KERNEL,
6782 wl, wlcore_nvs_cb);
6783 if (ret < 0) {
6784 wl1271_error("request_firmware_nowait failed for %s: %d",
6785 nvs_name, ret);
6786 complete_all(&wl->nvs_loading_complete);
6787 }
6788 } else {
6789 wlcore_nvs_cb(NULL, wl);
6790 }
6791
6792 wl->dev->driver->pm = &wlcore_pm_ops;
6793 pm_runtime_set_autosuspend_delay(wl->dev, 50);
6794 pm_runtime_use_autosuspend(wl->dev);
6795 pm_runtime_enable(wl->dev);
6796
6797 return ret;
6798 }
6799 EXPORT_SYMBOL_GPL(wlcore_probe);
6800
wlcore_remove(struct platform_device * pdev)6801 int wlcore_remove(struct platform_device *pdev)
6802 {
6803 struct wlcore_platdev_data *pdev_data = dev_get_platdata(&pdev->dev);
6804 struct wl1271 *wl = platform_get_drvdata(pdev);
6805 int error;
6806
6807 error = pm_runtime_get_sync(wl->dev);
6808 if (error < 0)
6809 dev_warn(wl->dev, "PM runtime failed: %i\n", error);
6810
6811 wl->dev->driver->pm = NULL;
6812
6813 if (pdev_data->family && pdev_data->family->nvs_name)
6814 wait_for_completion(&wl->nvs_loading_complete);
6815 if (!wl->initialized)
6816 return 0;
6817
6818 if (wl->irq_wake_enabled) {
6819 device_init_wakeup(wl->dev, 0);
6820 disable_irq_wake(wl->irq);
6821 }
6822 wl1271_unregister_hw(wl);
6823
6824 pm_runtime_put_sync(wl->dev);
6825 pm_runtime_dont_use_autosuspend(wl->dev);
6826 pm_runtime_disable(wl->dev);
6827
6828 free_irq(wl->irq, wl);
6829 wlcore_free_hw(wl);
6830
6831 return 0;
6832 }
6833 EXPORT_SYMBOL_GPL(wlcore_remove);
6834
6835 u32 wl12xx_debug_level = DEBUG_NONE;
6836 EXPORT_SYMBOL_GPL(wl12xx_debug_level);
6837 module_param_named(debug_level, wl12xx_debug_level, uint, 0600);
6838 MODULE_PARM_DESC(debug_level, "wl12xx debugging level");
6839
6840 module_param_named(fwlog, fwlog_param, charp, 0);
6841 MODULE_PARM_DESC(fwlog,
6842 "FW logger options: continuous, dbgpins or disable");
6843
6844 module_param(fwlog_mem_blocks, int, 0600);
6845 MODULE_PARM_DESC(fwlog_mem_blocks, "fwlog mem_blocks");
6846
6847 module_param(bug_on_recovery, int, 0600);
6848 MODULE_PARM_DESC(bug_on_recovery, "BUG() on fw recovery");
6849
6850 module_param(no_recovery, int, 0600);
6851 MODULE_PARM_DESC(no_recovery, "Prevent HW recovery. FW will remain stuck.");
6852
6853 MODULE_LICENSE("GPL");
6854 MODULE_AUTHOR("Luciano Coelho <coelho@ti.com>");
6855 MODULE_AUTHOR("Juuso Oikarinen <juuso.oikarinen@nokia.com>");
6856