blob: 7df23794ecd5ff9062e57770ce08853d21bf72cb [file] [log] [blame]
Kalle Valo5e3dd152013-06-12 20:52:10 +03001/*
2 * Copyright (c) 2005-2011 Atheros Communications Inc.
3 * Copyright (c) 2011-2013 Qualcomm Atheros, Inc.
4 *
5 * Permission to use, copy, modify, and/or distribute this software for any
6 * purpose with or without fee is hereby granted, provided that the above
7 * copyright notice and this permission notice appear in all copies.
8 *
9 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
10 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
11 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
12 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
13 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
14 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
15 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
16 */
17
18#include "mac.h"
19
20#include <net/mac80211.h>
21#include <linux/etherdevice.h>
22
Michal Kazior8cd13ca2013-07-16 09:38:54 +020023#include "hif.h"
Kalle Valo5e3dd152013-06-12 20:52:10 +030024#include "core.h"
25#include "debug.h"
26#include "wmi.h"
27#include "htt.h"
28#include "txrx.h"
Kalle Valo43d2a302014-09-10 18:23:30 +030029#include "testmode.h"
Kalle Valo5e3dd152013-06-12 20:52:10 +030030
31/**********/
32/* Crypto */
33/**********/
34
35static int ath10k_send_key(struct ath10k_vif *arvif,
36 struct ieee80211_key_conf *key,
37 enum set_key_cmd cmd,
38 const u8 *macaddr)
39{
Michal Kazior7aa7a722014-08-25 12:09:38 +020040 struct ath10k *ar = arvif->ar;
Kalle Valo5e3dd152013-06-12 20:52:10 +030041 struct wmi_vdev_install_key_arg arg = {
42 .vdev_id = arvif->vdev_id,
43 .key_idx = key->keyidx,
44 .key_len = key->keylen,
45 .key_data = key->key,
46 .macaddr = macaddr,
47 };
48
Michal Kazior548db542013-07-05 16:15:15 +030049 lockdep_assert_held(&arvif->ar->conf_mutex);
50
Kalle Valo5e3dd152013-06-12 20:52:10 +030051 if (key->flags & IEEE80211_KEY_FLAG_PAIRWISE)
52 arg.key_flags = WMI_KEY_PAIRWISE;
53 else
54 arg.key_flags = WMI_KEY_GROUP;
55
56 switch (key->cipher) {
57 case WLAN_CIPHER_SUITE_CCMP:
58 arg.key_cipher = WMI_CIPHER_AES_CCM;
Marek Kwaczynskieeab2662014-05-14 16:56:17 +030059 if (arvif->vdev_type == WMI_VDEV_TYPE_AP)
60 key->flags |= IEEE80211_KEY_FLAG_GENERATE_IV_MGMT;
61 else
62 key->flags |= IEEE80211_KEY_FLAG_SW_MGMT_TX;
Kalle Valo5e3dd152013-06-12 20:52:10 +030063 break;
64 case WLAN_CIPHER_SUITE_TKIP:
Kalle Valo5e3dd152013-06-12 20:52:10 +030065 arg.key_cipher = WMI_CIPHER_TKIP;
66 arg.key_txmic_len = 8;
67 arg.key_rxmic_len = 8;
68 break;
69 case WLAN_CIPHER_SUITE_WEP40:
70 case WLAN_CIPHER_SUITE_WEP104:
71 arg.key_cipher = WMI_CIPHER_WEP;
72 /* AP/IBSS mode requires self-key to be groupwise
73 * Otherwise pairwise key must be set */
74 if (memcmp(macaddr, arvif->vif->addr, ETH_ALEN))
75 arg.key_flags = WMI_KEY_PAIRWISE;
76 break;
77 default:
Michal Kazior7aa7a722014-08-25 12:09:38 +020078 ath10k_warn(ar, "cipher %d is not supported\n", key->cipher);
Kalle Valo5e3dd152013-06-12 20:52:10 +030079 return -EOPNOTSUPP;
80 }
81
82 if (cmd == DISABLE_KEY) {
83 arg.key_cipher = WMI_CIPHER_NONE;
84 arg.key_data = NULL;
85 }
86
87 return ath10k_wmi_vdev_install_key(arvif->ar, &arg);
88}
89
90static int ath10k_install_key(struct ath10k_vif *arvif,
91 struct ieee80211_key_conf *key,
92 enum set_key_cmd cmd,
93 const u8 *macaddr)
94{
95 struct ath10k *ar = arvif->ar;
96 int ret;
97
Michal Kazior548db542013-07-05 16:15:15 +030098 lockdep_assert_held(&ar->conf_mutex);
99
Wolfram Sang16735d02013-11-14 14:32:02 -0800100 reinit_completion(&ar->install_key_done);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300101
102 ret = ath10k_send_key(arvif, key, cmd, macaddr);
103 if (ret)
104 return ret;
105
106 ret = wait_for_completion_timeout(&ar->install_key_done, 3*HZ);
107 if (ret == 0)
108 return -ETIMEDOUT;
109
110 return 0;
111}
112
113static int ath10k_install_peer_wep_keys(struct ath10k_vif *arvif,
114 const u8 *addr)
115{
116 struct ath10k *ar = arvif->ar;
117 struct ath10k_peer *peer;
118 int ret;
119 int i;
120
121 lockdep_assert_held(&ar->conf_mutex);
122
123 spin_lock_bh(&ar->data_lock);
124 peer = ath10k_peer_find(ar, arvif->vdev_id, addr);
125 spin_unlock_bh(&ar->data_lock);
126
127 if (!peer)
128 return -ENOENT;
129
130 for (i = 0; i < ARRAY_SIZE(arvif->wep_keys); i++) {
131 if (arvif->wep_keys[i] == NULL)
132 continue;
133
134 ret = ath10k_install_key(arvif, arvif->wep_keys[i], SET_KEY,
135 addr);
136 if (ret)
137 return ret;
138
139 peer->keys[i] = arvif->wep_keys[i];
140 }
141
142 return 0;
143}
144
145static int ath10k_clear_peer_keys(struct ath10k_vif *arvif,
146 const u8 *addr)
147{
148 struct ath10k *ar = arvif->ar;
149 struct ath10k_peer *peer;
150 int first_errno = 0;
151 int ret;
152 int i;
153
154 lockdep_assert_held(&ar->conf_mutex);
155
156 spin_lock_bh(&ar->data_lock);
157 peer = ath10k_peer_find(ar, arvif->vdev_id, addr);
158 spin_unlock_bh(&ar->data_lock);
159
160 if (!peer)
161 return -ENOENT;
162
163 for (i = 0; i < ARRAY_SIZE(peer->keys); i++) {
164 if (peer->keys[i] == NULL)
165 continue;
166
167 ret = ath10k_install_key(arvif, peer->keys[i],
168 DISABLE_KEY, addr);
169 if (ret && first_errno == 0)
170 first_errno = ret;
171
172 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +0200173 ath10k_warn(ar, "failed to remove peer wep key %d: %d\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +0300174 i, ret);
175
176 peer->keys[i] = NULL;
177 }
178
179 return first_errno;
180}
181
182static int ath10k_clear_vdev_key(struct ath10k_vif *arvif,
183 struct ieee80211_key_conf *key)
184{
185 struct ath10k *ar = arvif->ar;
186 struct ath10k_peer *peer;
187 u8 addr[ETH_ALEN];
188 int first_errno = 0;
189 int ret;
190 int i;
191
192 lockdep_assert_held(&ar->conf_mutex);
193
194 for (;;) {
195 /* since ath10k_install_key we can't hold data_lock all the
196 * time, so we try to remove the keys incrementally */
197 spin_lock_bh(&ar->data_lock);
198 i = 0;
199 list_for_each_entry(peer, &ar->peers, list) {
200 for (i = 0; i < ARRAY_SIZE(peer->keys); i++) {
201 if (peer->keys[i] == key) {
Kalle Valob25f32c2014-09-14 12:50:49 +0300202 ether_addr_copy(addr, peer->addr);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300203 peer->keys[i] = NULL;
204 break;
205 }
206 }
207
208 if (i < ARRAY_SIZE(peer->keys))
209 break;
210 }
211 spin_unlock_bh(&ar->data_lock);
212
213 if (i == ARRAY_SIZE(peer->keys))
214 break;
215
216 ret = ath10k_install_key(arvif, key, DISABLE_KEY, addr);
217 if (ret && first_errno == 0)
218 first_errno = ret;
219
220 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +0200221 ath10k_warn(ar, "failed to remove key for %pM: %d\n",
Kalle Valobe6546f2014-03-25 14:18:51 +0200222 addr, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300223 }
224
225 return first_errno;
226}
227
Kalle Valo5e3dd152013-06-12 20:52:10 +0300228/*********************/
229/* General utilities */
230/*********************/
231
232static inline enum wmi_phy_mode
233chan_to_phymode(const struct cfg80211_chan_def *chandef)
234{
235 enum wmi_phy_mode phymode = MODE_UNKNOWN;
236
237 switch (chandef->chan->band) {
238 case IEEE80211_BAND_2GHZ:
239 switch (chandef->width) {
240 case NL80211_CHAN_WIDTH_20_NOHT:
241 phymode = MODE_11G;
242 break;
243 case NL80211_CHAN_WIDTH_20:
244 phymode = MODE_11NG_HT20;
245 break;
246 case NL80211_CHAN_WIDTH_40:
247 phymode = MODE_11NG_HT40;
248 break;
John W. Linville0f817ed2013-06-27 13:50:09 -0400249 case NL80211_CHAN_WIDTH_5:
250 case NL80211_CHAN_WIDTH_10:
Kalle Valo5e3dd152013-06-12 20:52:10 +0300251 case NL80211_CHAN_WIDTH_80:
252 case NL80211_CHAN_WIDTH_80P80:
253 case NL80211_CHAN_WIDTH_160:
254 phymode = MODE_UNKNOWN;
255 break;
256 }
257 break;
258 case IEEE80211_BAND_5GHZ:
259 switch (chandef->width) {
260 case NL80211_CHAN_WIDTH_20_NOHT:
261 phymode = MODE_11A;
262 break;
263 case NL80211_CHAN_WIDTH_20:
264 phymode = MODE_11NA_HT20;
265 break;
266 case NL80211_CHAN_WIDTH_40:
267 phymode = MODE_11NA_HT40;
268 break;
269 case NL80211_CHAN_WIDTH_80:
270 phymode = MODE_11AC_VHT80;
271 break;
John W. Linville0f817ed2013-06-27 13:50:09 -0400272 case NL80211_CHAN_WIDTH_5:
273 case NL80211_CHAN_WIDTH_10:
Kalle Valo5e3dd152013-06-12 20:52:10 +0300274 case NL80211_CHAN_WIDTH_80P80:
275 case NL80211_CHAN_WIDTH_160:
276 phymode = MODE_UNKNOWN;
277 break;
278 }
279 break;
280 default:
281 break;
282 }
283
284 WARN_ON(phymode == MODE_UNKNOWN);
285 return phymode;
286}
287
288static u8 ath10k_parse_mpdudensity(u8 mpdudensity)
289{
290/*
291 * 802.11n D2.0 defined values for "Minimum MPDU Start Spacing":
292 * 0 for no restriction
293 * 1 for 1/4 us
294 * 2 for 1/2 us
295 * 3 for 1 us
296 * 4 for 2 us
297 * 5 for 4 us
298 * 6 for 8 us
299 * 7 for 16 us
300 */
301 switch (mpdudensity) {
302 case 0:
303 return 0;
304 case 1:
305 case 2:
306 case 3:
307 /* Our lower layer calculations limit our precision to
308 1 microsecond */
309 return 1;
310 case 4:
311 return 2;
312 case 5:
313 return 4;
314 case 6:
315 return 8;
316 case 7:
317 return 16;
318 default:
319 return 0;
320 }
321}
322
323static int ath10k_peer_create(struct ath10k *ar, u32 vdev_id, const u8 *addr)
324{
325 int ret;
326
327 lockdep_assert_held(&ar->conf_mutex);
328
329 ret = ath10k_wmi_peer_create(ar, vdev_id, addr);
Ben Greear479398b2013-11-04 09:19:34 -0800330 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200331 ath10k_warn(ar, "failed to create wmi peer %pM on vdev %i: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +0200332 addr, vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300333 return ret;
Ben Greear479398b2013-11-04 09:19:34 -0800334 }
Kalle Valo5e3dd152013-06-12 20:52:10 +0300335
336 ret = ath10k_wait_for_peer_created(ar, vdev_id, addr);
Ben Greear479398b2013-11-04 09:19:34 -0800337 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200338 ath10k_warn(ar, "failed to wait for created wmi peer %pM on vdev %i: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +0200339 addr, vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300340 return ret;
Ben Greear479398b2013-11-04 09:19:34 -0800341 }
Bartosz Markowski0e759f32014-01-02 14:38:33 +0100342 spin_lock_bh(&ar->data_lock);
343 ar->num_peers++;
344 spin_unlock_bh(&ar->data_lock);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300345
346 return 0;
347}
348
Kalle Valo5a13e762014-01-20 11:01:46 +0200349static int ath10k_mac_set_kickout(struct ath10k_vif *arvif)
350{
351 struct ath10k *ar = arvif->ar;
352 u32 param;
353 int ret;
354
355 param = ar->wmi.pdev_param->sta_kickout_th;
356 ret = ath10k_wmi_pdev_set_param(ar, param,
357 ATH10K_KICKOUT_THRESHOLD);
358 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200359 ath10k_warn(ar, "failed to set kickout threshold on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200360 arvif->vdev_id, ret);
Kalle Valo5a13e762014-01-20 11:01:46 +0200361 return ret;
362 }
363
364 param = ar->wmi.vdev_param->ap_keepalive_min_idle_inactive_time_secs;
365 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, param,
366 ATH10K_KEEPALIVE_MIN_IDLE);
367 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200368 ath10k_warn(ar, "failed to set keepalive minimum idle time on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200369 arvif->vdev_id, ret);
Kalle Valo5a13e762014-01-20 11:01:46 +0200370 return ret;
371 }
372
373 param = ar->wmi.vdev_param->ap_keepalive_max_idle_inactive_time_secs;
374 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, param,
375 ATH10K_KEEPALIVE_MAX_IDLE);
376 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200377 ath10k_warn(ar, "failed to set keepalive maximum idle time on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200378 arvif->vdev_id, ret);
Kalle Valo5a13e762014-01-20 11:01:46 +0200379 return ret;
380 }
381
382 param = ar->wmi.vdev_param->ap_keepalive_max_unresponsive_time_secs;
383 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, param,
384 ATH10K_KEEPALIVE_MAX_UNRESPONSIVE);
385 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200386 ath10k_warn(ar, "failed to set keepalive maximum unresponsive time on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200387 arvif->vdev_id, ret);
Kalle Valo5a13e762014-01-20 11:01:46 +0200388 return ret;
389 }
390
391 return 0;
392}
393
Michal Kazior424121c2013-07-22 14:13:31 +0200394static int ath10k_mac_set_rts(struct ath10k_vif *arvif, u32 value)
395{
Bartosz Markowski6d1506e2013-09-26 17:47:15 +0200396 struct ath10k *ar = arvif->ar;
397 u32 vdev_param;
398
Michal Kazior424121c2013-07-22 14:13:31 +0200399 if (value != 0xFFFFFFFF)
400 value = min_t(u32, arvif->ar->hw->wiphy->rts_threshold,
401 ATH10K_RTS_MAX);
402
Bartosz Markowski6d1506e2013-09-26 17:47:15 +0200403 vdev_param = ar->wmi.vdev_param->rts_threshold;
404 return ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param, value);
Michal Kazior424121c2013-07-22 14:13:31 +0200405}
406
407static int ath10k_mac_set_frag(struct ath10k_vif *arvif, u32 value)
408{
Bartosz Markowski6d1506e2013-09-26 17:47:15 +0200409 struct ath10k *ar = arvif->ar;
410 u32 vdev_param;
411
Michal Kazior424121c2013-07-22 14:13:31 +0200412 if (value != 0xFFFFFFFF)
413 value = clamp_t(u32, arvif->ar->hw->wiphy->frag_threshold,
414 ATH10K_FRAGMT_THRESHOLD_MIN,
415 ATH10K_FRAGMT_THRESHOLD_MAX);
416
Bartosz Markowski6d1506e2013-09-26 17:47:15 +0200417 vdev_param = ar->wmi.vdev_param->fragmentation_threshold;
418 return ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param, value);
Michal Kazior424121c2013-07-22 14:13:31 +0200419}
420
Kalle Valo5e3dd152013-06-12 20:52:10 +0300421static int ath10k_peer_delete(struct ath10k *ar, u32 vdev_id, const u8 *addr)
422{
423 int ret;
424
425 lockdep_assert_held(&ar->conf_mutex);
426
427 ret = ath10k_wmi_peer_delete(ar, vdev_id, addr);
428 if (ret)
429 return ret;
430
431 ret = ath10k_wait_for_peer_deleted(ar, vdev_id, addr);
432 if (ret)
433 return ret;
434
Bartosz Markowski0e759f32014-01-02 14:38:33 +0100435 spin_lock_bh(&ar->data_lock);
436 ar->num_peers--;
437 spin_unlock_bh(&ar->data_lock);
438
Kalle Valo5e3dd152013-06-12 20:52:10 +0300439 return 0;
440}
441
442static void ath10k_peer_cleanup(struct ath10k *ar, u32 vdev_id)
443{
444 struct ath10k_peer *peer, *tmp;
445
446 lockdep_assert_held(&ar->conf_mutex);
447
448 spin_lock_bh(&ar->data_lock);
449 list_for_each_entry_safe(peer, tmp, &ar->peers, list) {
450 if (peer->vdev_id != vdev_id)
451 continue;
452
Michal Kazior7aa7a722014-08-25 12:09:38 +0200453 ath10k_warn(ar, "removing stale peer %pM from vdev_id %d\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +0300454 peer->addr, vdev_id);
455
456 list_del(&peer->list);
457 kfree(peer);
Bartosz Markowski0e759f32014-01-02 14:38:33 +0100458 ar->num_peers--;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300459 }
460 spin_unlock_bh(&ar->data_lock);
461}
462
Michal Kaziora96d7742013-07-16 09:38:56 +0200463static void ath10k_peer_cleanup_all(struct ath10k *ar)
464{
465 struct ath10k_peer *peer, *tmp;
466
467 lockdep_assert_held(&ar->conf_mutex);
468
469 spin_lock_bh(&ar->data_lock);
470 list_for_each_entry_safe(peer, tmp, &ar->peers, list) {
471 list_del(&peer->list);
472 kfree(peer);
473 }
Bartosz Markowski0e759f32014-01-02 14:38:33 +0100474 ar->num_peers = 0;
Michal Kaziora96d7742013-07-16 09:38:56 +0200475 spin_unlock_bh(&ar->data_lock);
476}
477
Kalle Valo5e3dd152013-06-12 20:52:10 +0300478/************************/
479/* Interface management */
480/************************/
481
Michal Kazior64badcb2014-09-18 11:18:02 +0300482void ath10k_mac_vif_beacon_free(struct ath10k_vif *arvif)
483{
484 struct ath10k *ar = arvif->ar;
485
486 lockdep_assert_held(&ar->data_lock);
487
488 if (!arvif->beacon)
489 return;
490
491 if (!arvif->beacon_buf)
492 dma_unmap_single(ar->dev, ATH10K_SKB_CB(arvif->beacon)->paddr,
493 arvif->beacon->len, DMA_TO_DEVICE);
494
495 dev_kfree_skb_any(arvif->beacon);
496
497 arvif->beacon = NULL;
498 arvif->beacon_sent = false;
499}
500
501static void ath10k_mac_vif_beacon_cleanup(struct ath10k_vif *arvif)
502{
503 struct ath10k *ar = arvif->ar;
504
505 lockdep_assert_held(&ar->data_lock);
506
507 ath10k_mac_vif_beacon_free(arvif);
508
509 if (arvif->beacon_buf) {
510 dma_free_coherent(ar->dev, IEEE80211_MAX_FRAME_LEN,
511 arvif->beacon_buf, arvif->beacon_paddr);
512 arvif->beacon_buf = NULL;
513 }
514}
515
Kalle Valo5e3dd152013-06-12 20:52:10 +0300516static inline int ath10k_vdev_setup_sync(struct ath10k *ar)
517{
518 int ret;
519
Michal Kazior548db542013-07-05 16:15:15 +0300520 lockdep_assert_held(&ar->conf_mutex);
521
Michal Kazior7962b0d2014-10-28 10:34:38 +0100522 if (test_bit(ATH10K_FLAG_CRASH_FLUSH, &ar->dev_flags))
523 return -ESHUTDOWN;
524
Kalle Valo5e3dd152013-06-12 20:52:10 +0300525 ret = wait_for_completion_timeout(&ar->vdev_setup_done,
526 ATH10K_VDEV_SETUP_TIMEOUT_HZ);
527 if (ret == 0)
528 return -ETIMEDOUT;
529
530 return 0;
531}
532
Michal Kazior1bbc0972014-04-08 09:45:47 +0300533static int ath10k_monitor_vdev_start(struct ath10k *ar, int vdev_id)
Kalle Valo5e3dd152013-06-12 20:52:10 +0300534{
Michal Kaziorc930f742014-01-23 11:38:25 +0100535 struct cfg80211_chan_def *chandef = &ar->chandef;
536 struct ieee80211_channel *channel = chandef->chan;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300537 struct wmi_vdev_start_request_arg arg = {};
Kalle Valo5e3dd152013-06-12 20:52:10 +0300538 int ret = 0;
539
540 lockdep_assert_held(&ar->conf_mutex);
541
Kalle Valo5e3dd152013-06-12 20:52:10 +0300542 arg.vdev_id = vdev_id;
543 arg.channel.freq = channel->center_freq;
Michal Kaziorc930f742014-01-23 11:38:25 +0100544 arg.channel.band_center_freq1 = chandef->center_freq1;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300545
546 /* TODO setup this dynamically, what in case we
547 don't have any vifs? */
Michal Kaziorc930f742014-01-23 11:38:25 +0100548 arg.channel.mode = chan_to_phymode(chandef);
Marek Puzyniake8a50f82013-11-20 09:59:47 +0200549 arg.channel.chan_radar =
550 !!(channel->flags & IEEE80211_CHAN_RADAR);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300551
Michal Kazior89c5c842013-10-23 04:02:13 -0700552 arg.channel.min_power = 0;
Michal Kazior02256932013-10-23 04:02:14 -0700553 arg.channel.max_power = channel->max_power * 2;
554 arg.channel.max_reg_power = channel->max_reg_power * 2;
555 arg.channel.max_antenna_gain = channel->max_antenna_gain * 2;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300556
Michal Kazior7962b0d2014-10-28 10:34:38 +0100557 reinit_completion(&ar->vdev_setup_done);
558
Kalle Valo5e3dd152013-06-12 20:52:10 +0300559 ret = ath10k_wmi_vdev_start(ar, &arg);
560 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200561 ath10k_warn(ar, "failed to request monitor vdev %i start: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200562 vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300563 return ret;
564 }
565
566 ret = ath10k_vdev_setup_sync(ar);
567 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200568 ath10k_warn(ar, "failed to synchronize setup for monitor vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200569 vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300570 return ret;
571 }
572
573 ret = ath10k_wmi_vdev_up(ar, vdev_id, 0, ar->mac_addr);
574 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200575 ath10k_warn(ar, "failed to put up monitor vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200576 vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300577 goto vdev_stop;
578 }
579
580 ar->monitor_vdev_id = vdev_id;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300581
Michal Kazior7aa7a722014-08-25 12:09:38 +0200582 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac monitor vdev %i started\n",
Michal Kazior1bbc0972014-04-08 09:45:47 +0300583 ar->monitor_vdev_id);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300584 return 0;
585
586vdev_stop:
587 ret = ath10k_wmi_vdev_stop(ar, ar->monitor_vdev_id);
588 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +0200589 ath10k_warn(ar, "failed to stop monitor vdev %i after start failure: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200590 ar->monitor_vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300591
592 return ret;
593}
594
Michal Kazior1bbc0972014-04-08 09:45:47 +0300595static int ath10k_monitor_vdev_stop(struct ath10k *ar)
Kalle Valo5e3dd152013-06-12 20:52:10 +0300596{
597 int ret = 0;
598
599 lockdep_assert_held(&ar->conf_mutex);
600
Marek Puzyniak52fa0192013-09-24 14:06:24 +0200601 ret = ath10k_wmi_vdev_down(ar, ar->monitor_vdev_id);
602 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +0200603 ath10k_warn(ar, "failed to put down monitor vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200604 ar->monitor_vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300605
Michal Kazior7962b0d2014-10-28 10:34:38 +0100606 reinit_completion(&ar->vdev_setup_done);
607
Kalle Valo5e3dd152013-06-12 20:52:10 +0300608 ret = ath10k_wmi_vdev_stop(ar, ar->monitor_vdev_id);
609 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +0200610 ath10k_warn(ar, "failed to to request monitor vdev %i stop: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200611 ar->monitor_vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300612
613 ret = ath10k_vdev_setup_sync(ar);
614 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +0200615 ath10k_warn(ar, "failed to synchronise monitor vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200616 ar->monitor_vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300617
Michal Kazior7aa7a722014-08-25 12:09:38 +0200618 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac monitor vdev %i stopped\n",
Michal Kazior1bbc0972014-04-08 09:45:47 +0300619 ar->monitor_vdev_id);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300620 return ret;
621}
622
Michal Kazior1bbc0972014-04-08 09:45:47 +0300623static int ath10k_monitor_vdev_create(struct ath10k *ar)
Kalle Valo5e3dd152013-06-12 20:52:10 +0300624{
625 int bit, ret = 0;
626
627 lockdep_assert_held(&ar->conf_mutex);
628
Ben Greeara9aefb32014-08-12 11:02:19 +0300629 if (ar->free_vdev_map == 0) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200630 ath10k_warn(ar, "failed to find free vdev id for monitor vdev\n");
Kalle Valo5e3dd152013-06-12 20:52:10 +0300631 return -ENOMEM;
632 }
633
Ben Greear16c11172014-09-23 14:17:16 -0700634 bit = __ffs64(ar->free_vdev_map);
Ben Greeara9aefb32014-08-12 11:02:19 +0300635
Ben Greear16c11172014-09-23 14:17:16 -0700636 ar->monitor_vdev_id = bit;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300637
638 ret = ath10k_wmi_vdev_create(ar, ar->monitor_vdev_id,
639 WMI_VDEV_TYPE_MONITOR,
640 0, ar->mac_addr);
641 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200642 ath10k_warn(ar, "failed to request monitor vdev %i creation: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200643 ar->monitor_vdev_id, ret);
Ben Greeara9aefb32014-08-12 11:02:19 +0300644 return ret;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300645 }
646
Ben Greear16c11172014-09-23 14:17:16 -0700647 ar->free_vdev_map &= ~(1LL << ar->monitor_vdev_id);
Michal Kazior7aa7a722014-08-25 12:09:38 +0200648 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac monitor vdev %d created\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +0300649 ar->monitor_vdev_id);
650
Kalle Valo5e3dd152013-06-12 20:52:10 +0300651 return 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300652}
653
Michal Kazior1bbc0972014-04-08 09:45:47 +0300654static int ath10k_monitor_vdev_delete(struct ath10k *ar)
Kalle Valo5e3dd152013-06-12 20:52:10 +0300655{
656 int ret = 0;
657
658 lockdep_assert_held(&ar->conf_mutex);
659
Kalle Valo5e3dd152013-06-12 20:52:10 +0300660 ret = ath10k_wmi_vdev_delete(ar, ar->monitor_vdev_id);
661 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200662 ath10k_warn(ar, "failed to request wmi monitor vdev %i removal: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200663 ar->monitor_vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300664 return ret;
665 }
666
Ben Greear16c11172014-09-23 14:17:16 -0700667 ar->free_vdev_map |= 1LL << ar->monitor_vdev_id;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300668
Michal Kazior7aa7a722014-08-25 12:09:38 +0200669 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac monitor vdev %d deleted\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +0300670 ar->monitor_vdev_id);
671 return ret;
672}
673
Michal Kazior1bbc0972014-04-08 09:45:47 +0300674static int ath10k_monitor_start(struct ath10k *ar)
675{
676 int ret;
677
678 lockdep_assert_held(&ar->conf_mutex);
679
Michal Kazior1bbc0972014-04-08 09:45:47 +0300680 ret = ath10k_monitor_vdev_create(ar);
681 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200682 ath10k_warn(ar, "failed to create monitor vdev: %d\n", ret);
Michal Kazior1bbc0972014-04-08 09:45:47 +0300683 return ret;
684 }
685
686 ret = ath10k_monitor_vdev_start(ar, ar->monitor_vdev_id);
687 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200688 ath10k_warn(ar, "failed to start monitor vdev: %d\n", ret);
Michal Kazior1bbc0972014-04-08 09:45:47 +0300689 ath10k_monitor_vdev_delete(ar);
690 return ret;
691 }
692
693 ar->monitor_started = true;
Michal Kazior7aa7a722014-08-25 12:09:38 +0200694 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac monitor started\n");
Michal Kazior1bbc0972014-04-08 09:45:47 +0300695
696 return 0;
697}
698
Michal Kazior19337472014-08-28 12:58:16 +0200699static int ath10k_monitor_stop(struct ath10k *ar)
Michal Kazior1bbc0972014-04-08 09:45:47 +0300700{
701 int ret;
702
703 lockdep_assert_held(&ar->conf_mutex);
704
Michal Kazior1bbc0972014-04-08 09:45:47 +0300705 ret = ath10k_monitor_vdev_stop(ar);
Michal Kazior19337472014-08-28 12:58:16 +0200706 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200707 ath10k_warn(ar, "failed to stop monitor vdev: %d\n", ret);
Michal Kazior19337472014-08-28 12:58:16 +0200708 return ret;
709 }
Michal Kazior1bbc0972014-04-08 09:45:47 +0300710
711 ret = ath10k_monitor_vdev_delete(ar);
Michal Kazior19337472014-08-28 12:58:16 +0200712 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200713 ath10k_warn(ar, "failed to delete monitor vdev: %d\n", ret);
Michal Kazior19337472014-08-28 12:58:16 +0200714 return ret;
715 }
Michal Kazior1bbc0972014-04-08 09:45:47 +0300716
717 ar->monitor_started = false;
Michal Kazior7aa7a722014-08-25 12:09:38 +0200718 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac monitor stopped\n");
Michal Kazior19337472014-08-28 12:58:16 +0200719
720 return 0;
721}
722
723static int ath10k_monitor_recalc(struct ath10k *ar)
724{
725 bool should_start;
726
727 lockdep_assert_held(&ar->conf_mutex);
728
729 should_start = ar->monitor ||
730 ar->filter_flags & FIF_PROMISC_IN_BSS ||
731 test_bit(ATH10K_CAC_RUNNING, &ar->dev_flags);
732
733 ath10k_dbg(ar, ATH10K_DBG_MAC,
734 "mac monitor recalc started? %d should? %d\n",
735 ar->monitor_started, should_start);
736
737 if (should_start == ar->monitor_started)
738 return 0;
739
740 if (should_start)
741 return ath10k_monitor_start(ar);
Kalle Valod8bb26b2014-09-14 12:50:33 +0300742
743 return ath10k_monitor_stop(ar);
Michal Kazior1bbc0972014-04-08 09:45:47 +0300744}
745
Marek Kwaczynskie81bd102014-03-11 12:58:00 +0200746static int ath10k_recalc_rtscts_prot(struct ath10k_vif *arvif)
747{
748 struct ath10k *ar = arvif->ar;
749 u32 vdev_param, rts_cts = 0;
750
751 lockdep_assert_held(&ar->conf_mutex);
752
753 vdev_param = ar->wmi.vdev_param->enable_rtscts;
754
755 if (arvif->use_cts_prot || arvif->num_legacy_stations > 0)
756 rts_cts |= SM(WMI_RTSCTS_ENABLED, WMI_RTSCTS_SET);
757
758 if (arvif->num_legacy_stations > 0)
759 rts_cts |= SM(WMI_RTSCTS_ACROSS_SW_RETRIES,
760 WMI_RTSCTS_PROFILE);
761
762 return ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
763 rts_cts);
764}
765
Marek Puzyniake8a50f82013-11-20 09:59:47 +0200766static int ath10k_start_cac(struct ath10k *ar)
767{
768 int ret;
769
770 lockdep_assert_held(&ar->conf_mutex);
771
772 set_bit(ATH10K_CAC_RUNNING, &ar->dev_flags);
773
Michal Kazior19337472014-08-28 12:58:16 +0200774 ret = ath10k_monitor_recalc(ar);
Marek Puzyniake8a50f82013-11-20 09:59:47 +0200775 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200776 ath10k_warn(ar, "failed to start monitor (cac): %d\n", ret);
Marek Puzyniake8a50f82013-11-20 09:59:47 +0200777 clear_bit(ATH10K_CAC_RUNNING, &ar->dev_flags);
778 return ret;
779 }
780
Michal Kazior7aa7a722014-08-25 12:09:38 +0200781 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac cac start monitor vdev %d\n",
Marek Puzyniake8a50f82013-11-20 09:59:47 +0200782 ar->monitor_vdev_id);
783
784 return 0;
785}
786
787static int ath10k_stop_cac(struct ath10k *ar)
788{
789 lockdep_assert_held(&ar->conf_mutex);
790
791 /* CAC is not running - do nothing */
792 if (!test_bit(ATH10K_CAC_RUNNING, &ar->dev_flags))
793 return 0;
794
Marek Puzyniake8a50f82013-11-20 09:59:47 +0200795 clear_bit(ATH10K_CAC_RUNNING, &ar->dev_flags);
Michal Kazior1bbc0972014-04-08 09:45:47 +0300796 ath10k_monitor_stop(ar);
Marek Puzyniake8a50f82013-11-20 09:59:47 +0200797
Michal Kazior7aa7a722014-08-25 12:09:38 +0200798 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac cac finished\n");
Marek Puzyniake8a50f82013-11-20 09:59:47 +0200799
800 return 0;
801}
802
Michal Kaziord6500972014-04-08 09:56:09 +0300803static void ath10k_recalc_radar_detection(struct ath10k *ar)
Marek Puzyniake8a50f82013-11-20 09:59:47 +0200804{
Marek Puzyniake8a50f82013-11-20 09:59:47 +0200805 int ret;
806
807 lockdep_assert_held(&ar->conf_mutex);
808
Marek Puzyniake8a50f82013-11-20 09:59:47 +0200809 ath10k_stop_cac(ar);
810
Michal Kaziord6500972014-04-08 09:56:09 +0300811 if (!ar->radar_enabled)
Marek Puzyniake8a50f82013-11-20 09:59:47 +0200812 return;
813
Michal Kaziord6500972014-04-08 09:56:09 +0300814 if (ar->num_started_vdevs > 0)
Marek Puzyniake8a50f82013-11-20 09:59:47 +0200815 return;
816
817 ret = ath10k_start_cac(ar);
818 if (ret) {
819 /*
820 * Not possible to start CAC on current channel so starting
821 * radiation is not allowed, make this channel DFS_UNAVAILABLE
822 * by indicating that radar was detected.
823 */
Michal Kazior7aa7a722014-08-25 12:09:38 +0200824 ath10k_warn(ar, "failed to start CAC: %d\n", ret);
Marek Puzyniake8a50f82013-11-20 09:59:47 +0200825 ieee80211_radar_detected(ar->hw);
826 }
827}
828
Michal Kaziordc55e302014-07-29 12:53:36 +0300829static int ath10k_vdev_start_restart(struct ath10k_vif *arvif, bool restart)
Michal Kazior72654fa2014-04-08 09:56:09 +0300830{
831 struct ath10k *ar = arvif->ar;
832 struct cfg80211_chan_def *chandef = &ar->chandef;
833 struct wmi_vdev_start_request_arg arg = {};
834 int ret = 0;
835
836 lockdep_assert_held(&ar->conf_mutex);
837
838 reinit_completion(&ar->vdev_setup_done);
839
840 arg.vdev_id = arvif->vdev_id;
841 arg.dtim_period = arvif->dtim_period;
842 arg.bcn_intval = arvif->beacon_interval;
843
844 arg.channel.freq = chandef->chan->center_freq;
845 arg.channel.band_center_freq1 = chandef->center_freq1;
846 arg.channel.mode = chan_to_phymode(chandef);
847
848 arg.channel.min_power = 0;
849 arg.channel.max_power = chandef->chan->max_power * 2;
850 arg.channel.max_reg_power = chandef->chan->max_reg_power * 2;
851 arg.channel.max_antenna_gain = chandef->chan->max_antenna_gain * 2;
852
853 if (arvif->vdev_type == WMI_VDEV_TYPE_AP) {
854 arg.ssid = arvif->u.ap.ssid;
855 arg.ssid_len = arvif->u.ap.ssid_len;
856 arg.hidden_ssid = arvif->u.ap.hidden_ssid;
857
858 /* For now allow DFS for AP mode */
859 arg.channel.chan_radar =
860 !!(chandef->chan->flags & IEEE80211_CHAN_RADAR);
861 } else if (arvif->vdev_type == WMI_VDEV_TYPE_IBSS) {
862 arg.ssid = arvif->vif->bss_conf.ssid;
863 arg.ssid_len = arvif->vif->bss_conf.ssid_len;
864 }
865
Michal Kazior7aa7a722014-08-25 12:09:38 +0200866 ath10k_dbg(ar, ATH10K_DBG_MAC,
Michal Kazior72654fa2014-04-08 09:56:09 +0300867 "mac vdev %d start center_freq %d phymode %s\n",
868 arg.vdev_id, arg.channel.freq,
869 ath10k_wmi_phymode_str(arg.channel.mode));
870
Michal Kaziordc55e302014-07-29 12:53:36 +0300871 if (restart)
872 ret = ath10k_wmi_vdev_restart(ar, &arg);
873 else
874 ret = ath10k_wmi_vdev_start(ar, &arg);
875
Michal Kazior72654fa2014-04-08 09:56:09 +0300876 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200877 ath10k_warn(ar, "failed to start WMI vdev %i: %d\n",
Michal Kazior72654fa2014-04-08 09:56:09 +0300878 arg.vdev_id, ret);
879 return ret;
880 }
881
882 ret = ath10k_vdev_setup_sync(ar);
883 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200884 ath10k_warn(ar, "failed to synchronise setup for vdev %i: %d\n",
Michal Kazior72654fa2014-04-08 09:56:09 +0300885 arg.vdev_id, ret);
886 return ret;
887 }
888
Michal Kaziord6500972014-04-08 09:56:09 +0300889 ar->num_started_vdevs++;
890 ath10k_recalc_radar_detection(ar);
891
Michal Kazior72654fa2014-04-08 09:56:09 +0300892 return ret;
893}
894
Michal Kaziordc55e302014-07-29 12:53:36 +0300895static int ath10k_vdev_start(struct ath10k_vif *arvif)
896{
897 return ath10k_vdev_start_restart(arvif, false);
898}
899
900static int ath10k_vdev_restart(struct ath10k_vif *arvif)
901{
902 return ath10k_vdev_start_restart(arvif, true);
903}
904
Michal Kazior72654fa2014-04-08 09:56:09 +0300905static int ath10k_vdev_stop(struct ath10k_vif *arvif)
906{
907 struct ath10k *ar = arvif->ar;
908 int ret;
909
910 lockdep_assert_held(&ar->conf_mutex);
911
912 reinit_completion(&ar->vdev_setup_done);
913
914 ret = ath10k_wmi_vdev_stop(ar, arvif->vdev_id);
915 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200916 ath10k_warn(ar, "failed to stop WMI vdev %i: %d\n",
Michal Kazior72654fa2014-04-08 09:56:09 +0300917 arvif->vdev_id, ret);
918 return ret;
919 }
920
921 ret = ath10k_vdev_setup_sync(ar);
922 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200923 ath10k_warn(ar, "failed to syncronise setup for vdev %i: %d\n",
Michal Kazior72654fa2014-04-08 09:56:09 +0300924 arvif->vdev_id, ret);
925 return ret;
926 }
927
Michal Kaziord6500972014-04-08 09:56:09 +0300928 WARN_ON(ar->num_started_vdevs == 0);
929
930 if (ar->num_started_vdevs != 0) {
931 ar->num_started_vdevs--;
932 ath10k_recalc_radar_detection(ar);
933 }
934
Michal Kazior72654fa2014-04-08 09:56:09 +0300935 return ret;
936}
937
Kalle Valo5e3dd152013-06-12 20:52:10 +0300938static void ath10k_control_beaconing(struct ath10k_vif *arvif,
Kalle Valo5b07e072014-09-14 12:50:06 +0300939 struct ieee80211_bss_conf *info)
Kalle Valo5e3dd152013-06-12 20:52:10 +0300940{
Michal Kazior7aa7a722014-08-25 12:09:38 +0200941 struct ath10k *ar = arvif->ar;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300942 int ret = 0;
943
Michal Kazior548db542013-07-05 16:15:15 +0300944 lockdep_assert_held(&arvif->ar->conf_mutex);
945
Kalle Valo5e3dd152013-06-12 20:52:10 +0300946 if (!info->enable_beacon) {
947 ath10k_vdev_stop(arvif);
Michal Kaziorc930f742014-01-23 11:38:25 +0100948
949 arvif->is_started = false;
950 arvif->is_up = false;
951
Michal Kazior748afc42014-01-23 12:48:21 +0100952 spin_lock_bh(&arvif->ar->data_lock);
Michal Kazior64badcb2014-09-18 11:18:02 +0300953 ath10k_mac_vif_beacon_free(arvif);
Michal Kazior748afc42014-01-23 12:48:21 +0100954 spin_unlock_bh(&arvif->ar->data_lock);
955
Kalle Valo5e3dd152013-06-12 20:52:10 +0300956 return;
957 }
958
959 arvif->tx_seq_no = 0x1000;
960
961 ret = ath10k_vdev_start(arvif);
962 if (ret)
963 return;
964
Michal Kaziorc930f742014-01-23 11:38:25 +0100965 arvif->aid = 0;
Kalle Valob25f32c2014-09-14 12:50:49 +0300966 ether_addr_copy(arvif->bssid, info->bssid);
Michal Kaziorc930f742014-01-23 11:38:25 +0100967
968 ret = ath10k_wmi_vdev_up(arvif->ar, arvif->vdev_id, arvif->aid,
969 arvif->bssid);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300970 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200971 ath10k_warn(ar, "failed to bring up vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +0200972 arvif->vdev_id, ret);
Michal Kaziorc930f742014-01-23 11:38:25 +0100973 ath10k_vdev_stop(arvif);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300974 return;
975 }
Michal Kaziorc930f742014-01-23 11:38:25 +0100976
977 arvif->is_started = true;
978 arvif->is_up = true;
979
Michal Kazior7aa7a722014-08-25 12:09:38 +0200980 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %d up\n", arvif->vdev_id);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300981}
982
983static void ath10k_control_ibss(struct ath10k_vif *arvif,
984 struct ieee80211_bss_conf *info,
985 const u8 self_peer[ETH_ALEN])
986{
Michal Kazior7aa7a722014-08-25 12:09:38 +0200987 struct ath10k *ar = arvif->ar;
Bartosz Markowski6d1506e2013-09-26 17:47:15 +0200988 u32 vdev_param;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300989 int ret = 0;
990
Michal Kazior548db542013-07-05 16:15:15 +0300991 lockdep_assert_held(&arvif->ar->conf_mutex);
992
Kalle Valo5e3dd152013-06-12 20:52:10 +0300993 if (!info->ibss_joined) {
994 ret = ath10k_peer_delete(arvif->ar, arvif->vdev_id, self_peer);
995 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +0200996 ath10k_warn(ar, "failed to delete IBSS self peer %pM for vdev %d: %d\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +0300997 self_peer, arvif->vdev_id, ret);
998
Michal Kaziorc930f742014-01-23 11:38:25 +0100999 if (is_zero_ether_addr(arvif->bssid))
Kalle Valo5e3dd152013-06-12 20:52:10 +03001000 return;
1001
Michal Kaziorc930f742014-01-23 11:38:25 +01001002 memset(arvif->bssid, 0, ETH_ALEN);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001003
1004 return;
1005 }
1006
1007 ret = ath10k_peer_create(arvif->ar, arvif->vdev_id, self_peer);
1008 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001009 ath10k_warn(ar, "failed to create IBSS self peer %pM for vdev %d: %d\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03001010 self_peer, arvif->vdev_id, ret);
1011 return;
1012 }
1013
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02001014 vdev_param = arvif->ar->wmi.vdev_param->atim_window;
1015 ret = ath10k_wmi_vdev_set_param(arvif->ar, arvif->vdev_id, vdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03001016 ATH10K_DEFAULT_ATIM);
1017 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02001018 ath10k_warn(ar, "failed to set IBSS ATIM for vdev %d: %d\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03001019 arvif->vdev_id, ret);
1020}
1021
1022/*
1023 * Review this when mac80211 gains per-interface powersave support.
1024 */
Michal Kaziorad088bf2013-10-16 15:44:46 +03001025static int ath10k_mac_vif_setup_ps(struct ath10k_vif *arvif)
Kalle Valo5e3dd152013-06-12 20:52:10 +03001026{
Michal Kaziorad088bf2013-10-16 15:44:46 +03001027 struct ath10k *ar = arvif->ar;
1028 struct ieee80211_conf *conf = &ar->hw->conf;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001029 enum wmi_sta_powersave_param param;
1030 enum wmi_sta_ps_mode psmode;
1031 int ret;
1032
Michal Kazior548db542013-07-05 16:15:15 +03001033 lockdep_assert_held(&arvif->ar->conf_mutex);
1034
Michal Kaziorad088bf2013-10-16 15:44:46 +03001035 if (arvif->vif->type != NL80211_IFTYPE_STATION)
1036 return 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001037
1038 if (conf->flags & IEEE80211_CONF_PS) {
1039 psmode = WMI_STA_PS_MODE_ENABLED;
1040 param = WMI_STA_PS_PARAM_INACTIVITY_TIME;
1041
Michal Kaziorad088bf2013-10-16 15:44:46 +03001042 ret = ath10k_wmi_set_sta_ps_param(ar, arvif->vdev_id, param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03001043 conf->dynamic_ps_timeout);
1044 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001045 ath10k_warn(ar, "failed to set inactivity time for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02001046 arvif->vdev_id, ret);
Michal Kaziorad088bf2013-10-16 15:44:46 +03001047 return ret;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001048 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03001049 } else {
1050 psmode = WMI_STA_PS_MODE_DISABLED;
1051 }
1052
Michal Kazior7aa7a722014-08-25 12:09:38 +02001053 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %d psmode %s\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03001054 arvif->vdev_id, psmode ? "enable" : "disable");
1055
Michal Kaziorad088bf2013-10-16 15:44:46 +03001056 ret = ath10k_wmi_set_psmode(ar, arvif->vdev_id, psmode);
1057 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001058 ath10k_warn(ar, "failed to set PS Mode %d for vdev %d: %d\n",
Kalle Valobe6546f2014-03-25 14:18:51 +02001059 psmode, arvif->vdev_id, ret);
Michal Kaziorad088bf2013-10-16 15:44:46 +03001060 return ret;
1061 }
1062
1063 return 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001064}
1065
1066/**********************/
1067/* Station management */
1068/**********************/
1069
Michal Kazior590922a2014-10-21 10:10:29 +03001070static u32 ath10k_peer_assoc_h_listen_intval(struct ath10k *ar,
1071 struct ieee80211_vif *vif)
1072{
1073 /* Some firmware revisions have unstable STA powersave when listen
1074 * interval is set too high (e.g. 5). The symptoms are firmware doesn't
1075 * generate NullFunc frames properly even if buffered frames have been
1076 * indicated in Beacon TIM. Firmware would seldom wake up to pull
1077 * buffered frames. Often pinging the device from AP would simply fail.
1078 *
1079 * As a workaround set it to 1.
1080 */
1081 if (vif->type == NL80211_IFTYPE_STATION)
1082 return 1;
1083
1084 return ar->hw->conf.listen_interval;
1085}
1086
Kalle Valo5e3dd152013-06-12 20:52:10 +03001087static void ath10k_peer_assoc_h_basic(struct ath10k *ar,
Michal Kazior590922a2014-10-21 10:10:29 +03001088 struct ieee80211_vif *vif,
Kalle Valo5e3dd152013-06-12 20:52:10 +03001089 struct ieee80211_sta *sta,
Kalle Valo5e3dd152013-06-12 20:52:10 +03001090 struct wmi_peer_assoc_complete_arg *arg)
1091{
Michal Kazior590922a2014-10-21 10:10:29 +03001092 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
1093
Michal Kazior548db542013-07-05 16:15:15 +03001094 lockdep_assert_held(&ar->conf_mutex);
1095
Kalle Valob25f32c2014-09-14 12:50:49 +03001096 ether_addr_copy(arg->addr, sta->addr);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001097 arg->vdev_id = arvif->vdev_id;
1098 arg->peer_aid = sta->aid;
1099 arg->peer_flags |= WMI_PEER_AUTH;
Michal Kazior590922a2014-10-21 10:10:29 +03001100 arg->peer_listen_intval = ath10k_peer_assoc_h_listen_intval(ar, vif);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001101 arg->peer_num_spatial_streams = 1;
Michal Kazior590922a2014-10-21 10:10:29 +03001102 arg->peer_caps = vif->bss_conf.assoc_capability;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001103}
1104
1105static void ath10k_peer_assoc_h_crypto(struct ath10k *ar,
Michal Kazior590922a2014-10-21 10:10:29 +03001106 struct ieee80211_vif *vif,
Kalle Valo5e3dd152013-06-12 20:52:10 +03001107 struct wmi_peer_assoc_complete_arg *arg)
1108{
Kalle Valo5e3dd152013-06-12 20:52:10 +03001109 struct ieee80211_bss_conf *info = &vif->bss_conf;
1110 struct cfg80211_bss *bss;
1111 const u8 *rsnie = NULL;
1112 const u8 *wpaie = NULL;
1113
Michal Kazior548db542013-07-05 16:15:15 +03001114 lockdep_assert_held(&ar->conf_mutex);
1115
Kalle Valo5e3dd152013-06-12 20:52:10 +03001116 bss = cfg80211_get_bss(ar->hw->wiphy, ar->hw->conf.chandef.chan,
1117 info->bssid, NULL, 0, 0, 0);
1118 if (bss) {
1119 const struct cfg80211_bss_ies *ies;
1120
1121 rcu_read_lock();
1122 rsnie = ieee80211_bss_get_ie(bss, WLAN_EID_RSN);
1123
1124 ies = rcu_dereference(bss->ies);
1125
1126 wpaie = cfg80211_find_vendor_ie(WLAN_OUI_MICROSOFT,
Kalle Valo5b07e072014-09-14 12:50:06 +03001127 WLAN_OUI_TYPE_MICROSOFT_WPA,
1128 ies->data,
1129 ies->len);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001130 rcu_read_unlock();
1131 cfg80211_put_bss(ar->hw->wiphy, bss);
1132 }
1133
1134 /* FIXME: base on RSN IE/WPA IE is a correct idea? */
1135 if (rsnie || wpaie) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001136 ath10k_dbg(ar, ATH10K_DBG_WMI, "%s: rsn ie found\n", __func__);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001137 arg->peer_flags |= WMI_PEER_NEED_PTK_4_WAY;
1138 }
1139
1140 if (wpaie) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001141 ath10k_dbg(ar, ATH10K_DBG_WMI, "%s: wpa ie found\n", __func__);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001142 arg->peer_flags |= WMI_PEER_NEED_GTK_2_WAY;
1143 }
1144}
1145
1146static void ath10k_peer_assoc_h_rates(struct ath10k *ar,
1147 struct ieee80211_sta *sta,
1148 struct wmi_peer_assoc_complete_arg *arg)
1149{
1150 struct wmi_rate_set_arg *rateset = &arg->peer_legacy_rates;
1151 const struct ieee80211_supported_band *sband;
1152 const struct ieee80211_rate *rates;
1153 u32 ratemask;
1154 int i;
1155
Michal Kazior548db542013-07-05 16:15:15 +03001156 lockdep_assert_held(&ar->conf_mutex);
1157
Kalle Valo5e3dd152013-06-12 20:52:10 +03001158 sband = ar->hw->wiphy->bands[ar->hw->conf.chandef.chan->band];
1159 ratemask = sta->supp_rates[ar->hw->conf.chandef.chan->band];
1160 rates = sband->bitrates;
1161
1162 rateset->num_rates = 0;
1163
1164 for (i = 0; i < 32; i++, ratemask >>= 1, rates++) {
1165 if (!(ratemask & 1))
1166 continue;
1167
1168 rateset->rates[rateset->num_rates] = rates->hw_value;
1169 rateset->num_rates++;
1170 }
1171}
1172
1173static void ath10k_peer_assoc_h_ht(struct ath10k *ar,
1174 struct ieee80211_sta *sta,
1175 struct wmi_peer_assoc_complete_arg *arg)
1176{
1177 const struct ieee80211_sta_ht_cap *ht_cap = &sta->ht_cap;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001178 int i, n;
Kalle Valoaf762c02014-09-14 12:50:17 +03001179 u32 stbc;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001180
Michal Kazior548db542013-07-05 16:15:15 +03001181 lockdep_assert_held(&ar->conf_mutex);
1182
Kalle Valo5e3dd152013-06-12 20:52:10 +03001183 if (!ht_cap->ht_supported)
1184 return;
1185
1186 arg->peer_flags |= WMI_PEER_HT;
1187 arg->peer_max_mpdu = (1 << (IEEE80211_HT_MAX_AMPDU_FACTOR +
1188 ht_cap->ampdu_factor)) - 1;
1189
1190 arg->peer_mpdu_density =
1191 ath10k_parse_mpdudensity(ht_cap->ampdu_density);
1192
1193 arg->peer_ht_caps = ht_cap->cap;
1194 arg->peer_rate_caps |= WMI_RC_HT_FLAG;
1195
1196 if (ht_cap->cap & IEEE80211_HT_CAP_LDPC_CODING)
1197 arg->peer_flags |= WMI_PEER_LDPC;
1198
1199 if (sta->bandwidth >= IEEE80211_STA_RX_BW_40) {
1200 arg->peer_flags |= WMI_PEER_40MHZ;
1201 arg->peer_rate_caps |= WMI_RC_CW40_FLAG;
1202 }
1203
1204 if (ht_cap->cap & IEEE80211_HT_CAP_SGI_20)
1205 arg->peer_rate_caps |= WMI_RC_SGI_FLAG;
1206
1207 if (ht_cap->cap & IEEE80211_HT_CAP_SGI_40)
1208 arg->peer_rate_caps |= WMI_RC_SGI_FLAG;
1209
1210 if (ht_cap->cap & IEEE80211_HT_CAP_TX_STBC) {
1211 arg->peer_rate_caps |= WMI_RC_TX_STBC_FLAG;
1212 arg->peer_flags |= WMI_PEER_STBC;
1213 }
1214
1215 if (ht_cap->cap & IEEE80211_HT_CAP_RX_STBC) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03001216 stbc = ht_cap->cap & IEEE80211_HT_CAP_RX_STBC;
1217 stbc = stbc >> IEEE80211_HT_CAP_RX_STBC_SHIFT;
1218 stbc = stbc << WMI_RC_RX_STBC_FLAG_S;
1219 arg->peer_rate_caps |= stbc;
1220 arg->peer_flags |= WMI_PEER_STBC;
1221 }
1222
Kalle Valo5e3dd152013-06-12 20:52:10 +03001223 if (ht_cap->mcs.rx_mask[1] && ht_cap->mcs.rx_mask[2])
1224 arg->peer_rate_caps |= WMI_RC_TS_FLAG;
1225 else if (ht_cap->mcs.rx_mask[1])
1226 arg->peer_rate_caps |= WMI_RC_DS_FLAG;
1227
1228 for (i = 0, n = 0; i < IEEE80211_HT_MCS_MASK_LEN*8; i++)
1229 if (ht_cap->mcs.rx_mask[i/8] & (1 << i%8))
1230 arg->peer_ht_rates.rates[n++] = i;
1231
Bartosz Markowskifd71f802014-02-10 13:12:55 +01001232 /*
1233 * This is a workaround for HT-enabled STAs which break the spec
1234 * and have no HT capabilities RX mask (no HT RX MCS map).
1235 *
1236 * As per spec, in section 20.3.5 Modulation and coding scheme (MCS),
1237 * MCS 0 through 7 are mandatory in 20MHz with 800 ns GI at all STAs.
1238 *
1239 * Firmware asserts if such situation occurs.
1240 */
1241 if (n == 0) {
1242 arg->peer_ht_rates.num_rates = 8;
1243 for (i = 0; i < arg->peer_ht_rates.num_rates; i++)
1244 arg->peer_ht_rates.rates[i] = i;
1245 } else {
1246 arg->peer_ht_rates.num_rates = n;
1247 arg->peer_num_spatial_streams = sta->rx_nss;
1248 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03001249
Michal Kazior7aa7a722014-08-25 12:09:38 +02001250 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac ht peer %pM mcs cnt %d nss %d\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03001251 arg->addr,
Kalle Valo5e3dd152013-06-12 20:52:10 +03001252 arg->peer_ht_rates.num_rates,
1253 arg->peer_num_spatial_streams);
1254}
1255
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01001256static int ath10k_peer_assoc_qos_ap(struct ath10k *ar,
1257 struct ath10k_vif *arvif,
1258 struct ieee80211_sta *sta)
Kalle Valo5e3dd152013-06-12 20:52:10 +03001259{
1260 u32 uapsd = 0;
1261 u32 max_sp = 0;
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01001262 int ret = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001263
Michal Kazior548db542013-07-05 16:15:15 +03001264 lockdep_assert_held(&ar->conf_mutex);
1265
Kalle Valo5e3dd152013-06-12 20:52:10 +03001266 if (sta->wme && sta->uapsd_queues) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001267 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac uapsd_queues 0x%x max_sp %d\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03001268 sta->uapsd_queues, sta->max_sp);
1269
Kalle Valo5e3dd152013-06-12 20:52:10 +03001270 if (sta->uapsd_queues & IEEE80211_WMM_IE_STA_QOSINFO_AC_VO)
1271 uapsd |= WMI_AP_PS_UAPSD_AC3_DELIVERY_EN |
1272 WMI_AP_PS_UAPSD_AC3_TRIGGER_EN;
1273 if (sta->uapsd_queues & IEEE80211_WMM_IE_STA_QOSINFO_AC_VI)
1274 uapsd |= WMI_AP_PS_UAPSD_AC2_DELIVERY_EN |
1275 WMI_AP_PS_UAPSD_AC2_TRIGGER_EN;
1276 if (sta->uapsd_queues & IEEE80211_WMM_IE_STA_QOSINFO_AC_BK)
1277 uapsd |= WMI_AP_PS_UAPSD_AC1_DELIVERY_EN |
1278 WMI_AP_PS_UAPSD_AC1_TRIGGER_EN;
1279 if (sta->uapsd_queues & IEEE80211_WMM_IE_STA_QOSINFO_AC_BE)
1280 uapsd |= WMI_AP_PS_UAPSD_AC0_DELIVERY_EN |
1281 WMI_AP_PS_UAPSD_AC0_TRIGGER_EN;
1282
Kalle Valo5e3dd152013-06-12 20:52:10 +03001283 if (sta->max_sp < MAX_WMI_AP_PS_PEER_PARAM_MAX_SP)
1284 max_sp = sta->max_sp;
1285
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01001286 ret = ath10k_wmi_set_ap_ps_param(ar, arvif->vdev_id,
1287 sta->addr,
1288 WMI_AP_PS_PEER_PARAM_UAPSD,
1289 uapsd);
1290 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001291 ath10k_warn(ar, "failed to set ap ps peer param uapsd for vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02001292 arvif->vdev_id, ret);
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01001293 return ret;
1294 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03001295
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01001296 ret = ath10k_wmi_set_ap_ps_param(ar, arvif->vdev_id,
1297 sta->addr,
1298 WMI_AP_PS_PEER_PARAM_MAX_SP,
1299 max_sp);
1300 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001301 ath10k_warn(ar, "failed to set ap ps peer param max sp for vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02001302 arvif->vdev_id, ret);
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01001303 return ret;
1304 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03001305
1306 /* TODO setup this based on STA listen interval and
1307 beacon interval. Currently we don't know
1308 sta->listen_interval - mac80211 patch required.
1309 Currently use 10 seconds */
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01001310 ret = ath10k_wmi_set_ap_ps_param(ar, arvif->vdev_id, sta->addr,
Kalle Valo5b07e072014-09-14 12:50:06 +03001311 WMI_AP_PS_PEER_PARAM_AGEOUT_TIME,
1312 10);
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01001313 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001314 ath10k_warn(ar, "failed to set ap ps peer param ageout time for vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02001315 arvif->vdev_id, ret);
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01001316 return ret;
1317 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03001318 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03001319
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01001320 return 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001321}
1322
1323static void ath10k_peer_assoc_h_vht(struct ath10k *ar,
1324 struct ieee80211_sta *sta,
1325 struct wmi_peer_assoc_complete_arg *arg)
1326{
1327 const struct ieee80211_sta_vht_cap *vht_cap = &sta->vht_cap;
Sujith Manoharana24b88b2013-10-07 19:51:57 -07001328 u8 ampdu_factor;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001329
1330 if (!vht_cap->vht_supported)
1331 return;
1332
1333 arg->peer_flags |= WMI_PEER_VHT;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001334 arg->peer_vht_caps = vht_cap->cap;
1335
Sujith Manoharana24b88b2013-10-07 19:51:57 -07001336 ampdu_factor = (vht_cap->cap &
1337 IEEE80211_VHT_CAP_MAX_A_MPDU_LENGTH_EXPONENT_MASK) >>
1338 IEEE80211_VHT_CAP_MAX_A_MPDU_LENGTH_EXPONENT_SHIFT;
1339
1340 /* Workaround: Some Netgear/Linksys 11ac APs set Rx A-MPDU factor to
1341 * zero in VHT IE. Using it would result in degraded throughput.
1342 * arg->peer_max_mpdu at this point contains HT max_mpdu so keep
1343 * it if VHT max_mpdu is smaller. */
1344 arg->peer_max_mpdu = max(arg->peer_max_mpdu,
1345 (1U << (IEEE80211_HT_MAX_AMPDU_FACTOR +
1346 ampdu_factor)) - 1);
1347
Kalle Valo5e3dd152013-06-12 20:52:10 +03001348 if (sta->bandwidth == IEEE80211_STA_RX_BW_80)
1349 arg->peer_flags |= WMI_PEER_80MHZ;
1350
1351 arg->peer_vht_rates.rx_max_rate =
1352 __le16_to_cpu(vht_cap->vht_mcs.rx_highest);
1353 arg->peer_vht_rates.rx_mcs_set =
1354 __le16_to_cpu(vht_cap->vht_mcs.rx_mcs_map);
1355 arg->peer_vht_rates.tx_max_rate =
1356 __le16_to_cpu(vht_cap->vht_mcs.tx_highest);
1357 arg->peer_vht_rates.tx_mcs_set =
1358 __le16_to_cpu(vht_cap->vht_mcs.tx_mcs_map);
1359
Michal Kazior7aa7a722014-08-25 12:09:38 +02001360 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vht peer %pM max_mpdu %d flags 0x%x\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03001361 sta->addr, arg->peer_max_mpdu, arg->peer_flags);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001362}
1363
1364static void ath10k_peer_assoc_h_qos(struct ath10k *ar,
Michal Kazior590922a2014-10-21 10:10:29 +03001365 struct ieee80211_vif *vif,
Kalle Valo5e3dd152013-06-12 20:52:10 +03001366 struct ieee80211_sta *sta,
Kalle Valo5e3dd152013-06-12 20:52:10 +03001367 struct wmi_peer_assoc_complete_arg *arg)
1368{
Michal Kazior590922a2014-10-21 10:10:29 +03001369 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
1370
Kalle Valo5e3dd152013-06-12 20:52:10 +03001371 switch (arvif->vdev_type) {
1372 case WMI_VDEV_TYPE_AP:
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01001373 if (sta->wme)
1374 arg->peer_flags |= WMI_PEER_QOS;
1375
1376 if (sta->wme && sta->uapsd_queues) {
1377 arg->peer_flags |= WMI_PEER_APSD;
1378 arg->peer_rate_caps |= WMI_RC_UAPSD_FLAG;
1379 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03001380 break;
1381 case WMI_VDEV_TYPE_STA:
Michal Kazior590922a2014-10-21 10:10:29 +03001382 if (vif->bss_conf.qos)
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01001383 arg->peer_flags |= WMI_PEER_QOS;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001384 break;
1385 default:
1386 break;
1387 }
1388}
1389
1390static void ath10k_peer_assoc_h_phymode(struct ath10k *ar,
Michal Kazior590922a2014-10-21 10:10:29 +03001391 struct ieee80211_vif *vif,
Kalle Valo5e3dd152013-06-12 20:52:10 +03001392 struct ieee80211_sta *sta,
1393 struct wmi_peer_assoc_complete_arg *arg)
1394{
1395 enum wmi_phy_mode phymode = MODE_UNKNOWN;
1396
Kalle Valo5e3dd152013-06-12 20:52:10 +03001397 switch (ar->hw->conf.chandef.chan->band) {
1398 case IEEE80211_BAND_2GHZ:
1399 if (sta->ht_cap.ht_supported) {
1400 if (sta->bandwidth == IEEE80211_STA_RX_BW_40)
1401 phymode = MODE_11NG_HT40;
1402 else
1403 phymode = MODE_11NG_HT20;
1404 } else {
1405 phymode = MODE_11G;
1406 }
1407
1408 break;
1409 case IEEE80211_BAND_5GHZ:
Sujith Manoharan7cc45e92013-09-08 18:19:55 +03001410 /*
1411 * Check VHT first.
1412 */
1413 if (sta->vht_cap.vht_supported) {
1414 if (sta->bandwidth == IEEE80211_STA_RX_BW_80)
1415 phymode = MODE_11AC_VHT80;
1416 else if (sta->bandwidth == IEEE80211_STA_RX_BW_40)
1417 phymode = MODE_11AC_VHT40;
1418 else if (sta->bandwidth == IEEE80211_STA_RX_BW_20)
1419 phymode = MODE_11AC_VHT20;
1420 } else if (sta->ht_cap.ht_supported) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03001421 if (sta->bandwidth == IEEE80211_STA_RX_BW_40)
1422 phymode = MODE_11NA_HT40;
1423 else
1424 phymode = MODE_11NA_HT20;
1425 } else {
1426 phymode = MODE_11A;
1427 }
1428
1429 break;
1430 default:
1431 break;
1432 }
1433
Michal Kazior7aa7a722014-08-25 12:09:38 +02001434 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac peer %pM phymode %s\n",
Kalle Valo38a1d472013-09-08 17:56:14 +03001435 sta->addr, ath10k_wmi_phymode_str(phymode));
Kalle Valo60c3daa2013-09-08 17:56:07 +03001436
Kalle Valo5e3dd152013-06-12 20:52:10 +03001437 arg->peer_phymode = phymode;
1438 WARN_ON(phymode == MODE_UNKNOWN);
1439}
1440
Kalle Valob9ada652013-10-16 15:44:46 +03001441static int ath10k_peer_assoc_prepare(struct ath10k *ar,
Michal Kazior590922a2014-10-21 10:10:29 +03001442 struct ieee80211_vif *vif,
Kalle Valob9ada652013-10-16 15:44:46 +03001443 struct ieee80211_sta *sta,
Kalle Valob9ada652013-10-16 15:44:46 +03001444 struct wmi_peer_assoc_complete_arg *arg)
Kalle Valo5e3dd152013-06-12 20:52:10 +03001445{
Michal Kazior548db542013-07-05 16:15:15 +03001446 lockdep_assert_held(&ar->conf_mutex);
1447
Kalle Valob9ada652013-10-16 15:44:46 +03001448 memset(arg, 0, sizeof(*arg));
Kalle Valo5e3dd152013-06-12 20:52:10 +03001449
Michal Kazior590922a2014-10-21 10:10:29 +03001450 ath10k_peer_assoc_h_basic(ar, vif, sta, arg);
1451 ath10k_peer_assoc_h_crypto(ar, vif, arg);
Kalle Valob9ada652013-10-16 15:44:46 +03001452 ath10k_peer_assoc_h_rates(ar, sta, arg);
1453 ath10k_peer_assoc_h_ht(ar, sta, arg);
1454 ath10k_peer_assoc_h_vht(ar, sta, arg);
Michal Kazior590922a2014-10-21 10:10:29 +03001455 ath10k_peer_assoc_h_qos(ar, vif, sta, arg);
1456 ath10k_peer_assoc_h_phymode(ar, vif, sta, arg);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001457
Kalle Valob9ada652013-10-16 15:44:46 +03001458 return 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001459}
1460
Michal Kazior90046f52014-02-14 14:45:51 +01001461static const u32 ath10k_smps_map[] = {
1462 [WLAN_HT_CAP_SM_PS_STATIC] = WMI_PEER_SMPS_STATIC,
1463 [WLAN_HT_CAP_SM_PS_DYNAMIC] = WMI_PEER_SMPS_DYNAMIC,
1464 [WLAN_HT_CAP_SM_PS_INVALID] = WMI_PEER_SMPS_PS_NONE,
1465 [WLAN_HT_CAP_SM_PS_DISABLED] = WMI_PEER_SMPS_PS_NONE,
1466};
1467
1468static int ath10k_setup_peer_smps(struct ath10k *ar, struct ath10k_vif *arvif,
1469 const u8 *addr,
1470 const struct ieee80211_sta_ht_cap *ht_cap)
1471{
1472 int smps;
1473
1474 if (!ht_cap->ht_supported)
1475 return 0;
1476
1477 smps = ht_cap->cap & IEEE80211_HT_CAP_SM_PS;
1478 smps >>= IEEE80211_HT_CAP_SM_PS_SHIFT;
1479
1480 if (smps >= ARRAY_SIZE(ath10k_smps_map))
1481 return -EINVAL;
1482
1483 return ath10k_wmi_peer_set_param(ar, arvif->vdev_id, addr,
1484 WMI_PEER_SMPS_STATE,
1485 ath10k_smps_map[smps]);
1486}
1487
Kalle Valo5e3dd152013-06-12 20:52:10 +03001488/* can be called only in mac80211 callbacks due to `key_count` usage */
1489static void ath10k_bss_assoc(struct ieee80211_hw *hw,
1490 struct ieee80211_vif *vif,
1491 struct ieee80211_bss_conf *bss_conf)
1492{
1493 struct ath10k *ar = hw->priv;
1494 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kazior90046f52014-02-14 14:45:51 +01001495 struct ieee80211_sta_ht_cap ht_cap;
Kalle Valob9ada652013-10-16 15:44:46 +03001496 struct wmi_peer_assoc_complete_arg peer_arg;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001497 struct ieee80211_sta *ap_sta;
1498 int ret;
1499
Michal Kazior548db542013-07-05 16:15:15 +03001500 lockdep_assert_held(&ar->conf_mutex);
1501
Michal Kazior077efc82014-10-21 10:10:29 +03001502 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %i assoc bssid %pM aid %d\n",
1503 arvif->vdev_id, arvif->bssid, arvif->aid);
1504
Kalle Valo5e3dd152013-06-12 20:52:10 +03001505 rcu_read_lock();
1506
1507 ap_sta = ieee80211_find_sta(vif, bss_conf->bssid);
1508 if (!ap_sta) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001509 ath10k_warn(ar, "failed to find station entry for bss %pM vdev %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02001510 bss_conf->bssid, arvif->vdev_id);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001511 rcu_read_unlock();
1512 return;
1513 }
1514
Michal Kazior90046f52014-02-14 14:45:51 +01001515 /* ap_sta must be accessed only within rcu section which must be left
1516 * before calling ath10k_setup_peer_smps() which might sleep. */
1517 ht_cap = ap_sta->ht_cap;
1518
Michal Kazior590922a2014-10-21 10:10:29 +03001519 ret = ath10k_peer_assoc_prepare(ar, vif, ap_sta, &peer_arg);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001520 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001521 ath10k_warn(ar, "failed to prepare peer assoc for %pM vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02001522 bss_conf->bssid, arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001523 rcu_read_unlock();
1524 return;
1525 }
1526
1527 rcu_read_unlock();
1528
Kalle Valob9ada652013-10-16 15:44:46 +03001529 ret = ath10k_wmi_peer_assoc(ar, &peer_arg);
1530 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001531 ath10k_warn(ar, "failed to run peer assoc for %pM vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02001532 bss_conf->bssid, arvif->vdev_id, ret);
Kalle Valob9ada652013-10-16 15:44:46 +03001533 return;
1534 }
1535
Michal Kazior90046f52014-02-14 14:45:51 +01001536 ret = ath10k_setup_peer_smps(ar, arvif, bss_conf->bssid, &ht_cap);
1537 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001538 ath10k_warn(ar, "failed to setup peer SMPS for vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02001539 arvif->vdev_id, ret);
Michal Kazior90046f52014-02-14 14:45:51 +01001540 return;
1541 }
1542
Michal Kazior7aa7a722014-08-25 12:09:38 +02001543 ath10k_dbg(ar, ATH10K_DBG_MAC,
Kalle Valo60c3daa2013-09-08 17:56:07 +03001544 "mac vdev %d up (associated) bssid %pM aid %d\n",
1545 arvif->vdev_id, bss_conf->bssid, bss_conf->aid);
1546
Michal Kazior077efc82014-10-21 10:10:29 +03001547 WARN_ON(arvif->is_up);
1548
Michal Kaziorc930f742014-01-23 11:38:25 +01001549 arvif->aid = bss_conf->aid;
Kalle Valob25f32c2014-09-14 12:50:49 +03001550 ether_addr_copy(arvif->bssid, bss_conf->bssid);
Michal Kaziorc930f742014-01-23 11:38:25 +01001551
1552 ret = ath10k_wmi_vdev_up(ar, arvif->vdev_id, arvif->aid, arvif->bssid);
1553 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001554 ath10k_warn(ar, "failed to set vdev %d up: %d\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03001555 arvif->vdev_id, ret);
Michal Kaziorc930f742014-01-23 11:38:25 +01001556 return;
1557 }
1558
1559 arvif->is_up = true;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001560}
1561
Kalle Valo5e3dd152013-06-12 20:52:10 +03001562static void ath10k_bss_disassoc(struct ieee80211_hw *hw,
1563 struct ieee80211_vif *vif)
1564{
1565 struct ath10k *ar = hw->priv;
1566 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
1567 int ret;
1568
Michal Kazior548db542013-07-05 16:15:15 +03001569 lockdep_assert_held(&ar->conf_mutex);
1570
Michal Kazior077efc82014-10-21 10:10:29 +03001571 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %i disassoc bssid %pM\n",
1572 arvif->vdev_id, arvif->bssid);
Kalle Valo60c3daa2013-09-08 17:56:07 +03001573
Kalle Valo5e3dd152013-06-12 20:52:10 +03001574 ret = ath10k_wmi_vdev_down(ar, arvif->vdev_id);
Michal Kazior077efc82014-10-21 10:10:29 +03001575 if (ret)
1576 ath10k_warn(ar, "faield to down vdev %i: %d\n",
1577 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001578
Michal Kaziorcc4827b2013-10-16 15:44:45 +03001579 arvif->def_wep_key_idx = 0;
Michal Kaziorc930f742014-01-23 11:38:25 +01001580 arvif->is_up = false;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001581}
1582
Michal Kazior590922a2014-10-21 10:10:29 +03001583static int ath10k_station_assoc(struct ath10k *ar,
1584 struct ieee80211_vif *vif,
1585 struct ieee80211_sta *sta,
1586 bool reassoc)
Kalle Valo5e3dd152013-06-12 20:52:10 +03001587{
Michal Kazior590922a2014-10-21 10:10:29 +03001588 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Kalle Valob9ada652013-10-16 15:44:46 +03001589 struct wmi_peer_assoc_complete_arg peer_arg;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001590 int ret = 0;
1591
Michal Kazior548db542013-07-05 16:15:15 +03001592 lockdep_assert_held(&ar->conf_mutex);
1593
Michal Kazior590922a2014-10-21 10:10:29 +03001594 ret = ath10k_peer_assoc_prepare(ar, vif, sta, &peer_arg);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001595 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001596 ath10k_warn(ar, "failed to prepare WMI peer assoc for %pM vdev %i: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02001597 sta->addr, arvif->vdev_id, ret);
Kalle Valob9ada652013-10-16 15:44:46 +03001598 return ret;
1599 }
1600
Chun-Yeow Yeoh44d6fa92014-03-07 10:19:30 +02001601 peer_arg.peer_reassoc = reassoc;
Kalle Valob9ada652013-10-16 15:44:46 +03001602 ret = ath10k_wmi_peer_assoc(ar, &peer_arg);
1603 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001604 ath10k_warn(ar, "failed to run peer assoc for STA %pM vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02001605 sta->addr, arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001606 return ret;
1607 }
1608
Michal Kaziorb1ecde32014-10-21 10:10:29 +03001609 /* Re-assoc is run only to update supported rates for given station. It
1610 * doesn't make much sense to reconfigure the peer completely.
1611 */
1612 if (!reassoc) {
1613 ret = ath10k_setup_peer_smps(ar, arvif, sta->addr,
1614 &sta->ht_cap);
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02001615 if (ret) {
Michal Kaziorb1ecde32014-10-21 10:10:29 +03001616 ath10k_warn(ar, "failed to setup peer SMPS for vdev %d: %d\n",
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02001617 arvif->vdev_id, ret);
1618 return ret;
1619 }
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02001620
Michal Kaziorb1ecde32014-10-21 10:10:29 +03001621 ret = ath10k_peer_assoc_qos_ap(ar, arvif, sta);
1622 if (ret) {
1623 ath10k_warn(ar, "failed to set qos params for STA %pM for vdev %i: %d\n",
1624 sta->addr, arvif->vdev_id, ret);
1625 return ret;
1626 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03001627
Michal Kaziorb1ecde32014-10-21 10:10:29 +03001628 if (!sta->wme) {
1629 arvif->num_legacy_stations++;
1630 ret = ath10k_recalc_rtscts_prot(arvif);
1631 if (ret) {
1632 ath10k_warn(ar, "failed to recalculate rts/cts prot for vdev %d: %d\n",
1633 arvif->vdev_id, ret);
1634 return ret;
1635 }
1636 }
1637
1638 ret = ath10k_install_peer_wep_keys(arvif, sta->addr);
1639 if (ret) {
1640 ath10k_warn(ar, "failed to install peer wep keys for vdev %i: %d\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03001641 arvif->vdev_id, ret);
1642 return ret;
1643 }
1644 }
1645
Kalle Valo5e3dd152013-06-12 20:52:10 +03001646 return ret;
1647}
1648
Michal Kazior590922a2014-10-21 10:10:29 +03001649static int ath10k_station_disassoc(struct ath10k *ar,
1650 struct ieee80211_vif *vif,
Kalle Valo5e3dd152013-06-12 20:52:10 +03001651 struct ieee80211_sta *sta)
1652{
Michal Kazior590922a2014-10-21 10:10:29 +03001653 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001654 int ret = 0;
1655
1656 lockdep_assert_held(&ar->conf_mutex);
1657
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02001658 if (!sta->wme) {
1659 arvif->num_legacy_stations--;
1660 ret = ath10k_recalc_rtscts_prot(arvif);
1661 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001662 ath10k_warn(ar, "failed to recalculate rts/cts prot for vdev %d: %d\n",
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02001663 arvif->vdev_id, ret);
1664 return ret;
1665 }
1666 }
1667
Kalle Valo5e3dd152013-06-12 20:52:10 +03001668 ret = ath10k_clear_peer_keys(arvif, sta->addr);
1669 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001670 ath10k_warn(ar, "failed to clear all peer wep keys for vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02001671 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001672 return ret;
1673 }
1674
1675 return ret;
1676}
1677
1678/**************/
1679/* Regulatory */
1680/**************/
1681
1682static int ath10k_update_channel_list(struct ath10k *ar)
1683{
1684 struct ieee80211_hw *hw = ar->hw;
1685 struct ieee80211_supported_band **bands;
1686 enum ieee80211_band band;
1687 struct ieee80211_channel *channel;
1688 struct wmi_scan_chan_list_arg arg = {0};
1689 struct wmi_channel_arg *ch;
1690 bool passive;
1691 int len;
1692 int ret;
1693 int i;
1694
Michal Kazior548db542013-07-05 16:15:15 +03001695 lockdep_assert_held(&ar->conf_mutex);
1696
Kalle Valo5e3dd152013-06-12 20:52:10 +03001697 bands = hw->wiphy->bands;
1698 for (band = 0; band < IEEE80211_NUM_BANDS; band++) {
1699 if (!bands[band])
1700 continue;
1701
1702 for (i = 0; i < bands[band]->n_channels; i++) {
1703 if (bands[band]->channels[i].flags &
1704 IEEE80211_CHAN_DISABLED)
1705 continue;
1706
1707 arg.n_channels++;
1708 }
1709 }
1710
1711 len = sizeof(struct wmi_channel_arg) * arg.n_channels;
1712 arg.channels = kzalloc(len, GFP_KERNEL);
1713 if (!arg.channels)
1714 return -ENOMEM;
1715
1716 ch = arg.channels;
1717 for (band = 0; band < IEEE80211_NUM_BANDS; band++) {
1718 if (!bands[band])
1719 continue;
1720
1721 for (i = 0; i < bands[band]->n_channels; i++) {
1722 channel = &bands[band]->channels[i];
1723
1724 if (channel->flags & IEEE80211_CHAN_DISABLED)
1725 continue;
1726
1727 ch->allow_ht = true;
1728
1729 /* FIXME: when should we really allow VHT? */
1730 ch->allow_vht = true;
1731
1732 ch->allow_ibss =
Luis R. Rodriguez8fe02e12013-10-21 19:22:25 +02001733 !(channel->flags & IEEE80211_CHAN_NO_IR);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001734
1735 ch->ht40plus =
1736 !(channel->flags & IEEE80211_CHAN_NO_HT40PLUS);
1737
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001738 ch->chan_radar =
1739 !!(channel->flags & IEEE80211_CHAN_RADAR);
1740
Luis R. Rodriguez8fe02e12013-10-21 19:22:25 +02001741 passive = channel->flags & IEEE80211_CHAN_NO_IR;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001742 ch->passive = passive;
1743
1744 ch->freq = channel->center_freq;
Michal Kazior2d667212014-09-18 15:21:21 +02001745 ch->band_center_freq1 = channel->center_freq;
Michal Kazior89c5c842013-10-23 04:02:13 -07001746 ch->min_power = 0;
Michal Kazior02256932013-10-23 04:02:14 -07001747 ch->max_power = channel->max_power * 2;
1748 ch->max_reg_power = channel->max_reg_power * 2;
1749 ch->max_antenna_gain = channel->max_antenna_gain * 2;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001750 ch->reg_class_id = 0; /* FIXME */
1751
1752 /* FIXME: why use only legacy modes, why not any
1753 * HT/VHT modes? Would that even make any
1754 * difference? */
1755 if (channel->band == IEEE80211_BAND_2GHZ)
1756 ch->mode = MODE_11G;
1757 else
1758 ch->mode = MODE_11A;
1759
1760 if (WARN_ON_ONCE(ch->mode == MODE_UNKNOWN))
1761 continue;
1762
Michal Kazior7aa7a722014-08-25 12:09:38 +02001763 ath10k_dbg(ar, ATH10K_DBG_WMI,
Kalle Valo60c3daa2013-09-08 17:56:07 +03001764 "mac channel [%zd/%d] freq %d maxpower %d regpower %d antenna %d mode %d\n",
1765 ch - arg.channels, arg.n_channels,
Kalle Valo5e3dd152013-06-12 20:52:10 +03001766 ch->freq, ch->max_power, ch->max_reg_power,
1767 ch->max_antenna_gain, ch->mode);
1768
1769 ch++;
1770 }
1771 }
1772
1773 ret = ath10k_wmi_scan_chan_list(ar, &arg);
1774 kfree(arg.channels);
1775
1776 return ret;
1777}
1778
Marek Puzyniak821af6a2014-03-21 17:46:57 +02001779static enum wmi_dfs_region
1780ath10k_mac_get_dfs_region(enum nl80211_dfs_regions dfs_region)
1781{
1782 switch (dfs_region) {
1783 case NL80211_DFS_UNSET:
1784 return WMI_UNINIT_DFS_DOMAIN;
1785 case NL80211_DFS_FCC:
1786 return WMI_FCC_DFS_DOMAIN;
1787 case NL80211_DFS_ETSI:
1788 return WMI_ETSI_DFS_DOMAIN;
1789 case NL80211_DFS_JP:
1790 return WMI_MKK4_DFS_DOMAIN;
1791 }
1792 return WMI_UNINIT_DFS_DOMAIN;
1793}
1794
Michal Kaziorf7843d72013-07-16 09:38:52 +02001795static void ath10k_regd_update(struct ath10k *ar)
Kalle Valo5e3dd152013-06-12 20:52:10 +03001796{
Kalle Valo5e3dd152013-06-12 20:52:10 +03001797 struct reg_dmn_pair_mapping *regpair;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001798 int ret;
Marek Puzyniak821af6a2014-03-21 17:46:57 +02001799 enum wmi_dfs_region wmi_dfs_reg;
1800 enum nl80211_dfs_regions nl_dfs_reg;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001801
Michal Kaziorf7843d72013-07-16 09:38:52 +02001802 lockdep_assert_held(&ar->conf_mutex);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001803
1804 ret = ath10k_update_channel_list(ar);
1805 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02001806 ath10k_warn(ar, "failed to update channel list: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001807
1808 regpair = ar->ath_common.regulatory.regpair;
Michal Kaziorf7843d72013-07-16 09:38:52 +02001809
Marek Puzyniak821af6a2014-03-21 17:46:57 +02001810 if (config_enabled(CONFIG_ATH10K_DFS_CERTIFIED) && ar->dfs_detector) {
1811 nl_dfs_reg = ar->dfs_detector->region;
1812 wmi_dfs_reg = ath10k_mac_get_dfs_region(nl_dfs_reg);
1813 } else {
1814 wmi_dfs_reg = WMI_UNINIT_DFS_DOMAIN;
1815 }
1816
Kalle Valo5e3dd152013-06-12 20:52:10 +03001817 /* Target allows setting up per-band regdomain but ath_common provides
1818 * a combined one only */
1819 ret = ath10k_wmi_pdev_set_regdomain(ar,
Kalle Valoef8c0012014-02-13 18:13:12 +02001820 regpair->reg_domain,
1821 regpair->reg_domain, /* 2ghz */
1822 regpair->reg_domain, /* 5ghz */
Kalle Valo5e3dd152013-06-12 20:52:10 +03001823 regpair->reg_2ghz_ctl,
Marek Puzyniak821af6a2014-03-21 17:46:57 +02001824 regpair->reg_5ghz_ctl,
1825 wmi_dfs_reg);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001826 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02001827 ath10k_warn(ar, "failed to set pdev regdomain: %d\n", ret);
Michal Kaziorf7843d72013-07-16 09:38:52 +02001828}
Michal Kazior548db542013-07-05 16:15:15 +03001829
Michal Kaziorf7843d72013-07-16 09:38:52 +02001830static void ath10k_reg_notifier(struct wiphy *wiphy,
1831 struct regulatory_request *request)
1832{
1833 struct ieee80211_hw *hw = wiphy_to_ieee80211_hw(wiphy);
1834 struct ath10k *ar = hw->priv;
Janusz Dziedzic9702c682013-11-20 09:59:41 +02001835 bool result;
Michal Kaziorf7843d72013-07-16 09:38:52 +02001836
1837 ath_reg_notifier_apply(wiphy, request, &ar->ath_common.regulatory);
1838
Janusz Dziedzic9702c682013-11-20 09:59:41 +02001839 if (config_enabled(CONFIG_ATH10K_DFS_CERTIFIED) && ar->dfs_detector) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001840 ath10k_dbg(ar, ATH10K_DBG_REGULATORY, "dfs region 0x%x\n",
Janusz Dziedzic9702c682013-11-20 09:59:41 +02001841 request->dfs_region);
1842 result = ar->dfs_detector->set_dfs_domain(ar->dfs_detector,
1843 request->dfs_region);
1844 if (!result)
Michal Kazior7aa7a722014-08-25 12:09:38 +02001845 ath10k_warn(ar, "DFS region 0x%X not supported, will trigger radar for every pulse\n",
Janusz Dziedzic9702c682013-11-20 09:59:41 +02001846 request->dfs_region);
1847 }
1848
Michal Kaziorf7843d72013-07-16 09:38:52 +02001849 mutex_lock(&ar->conf_mutex);
1850 if (ar->state == ATH10K_STATE_ON)
1851 ath10k_regd_update(ar);
Michal Kazior548db542013-07-05 16:15:15 +03001852 mutex_unlock(&ar->conf_mutex);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001853}
1854
1855/***************/
1856/* TX handlers */
1857/***************/
1858
Michal Kazior42c3aa62013-10-02 11:03:38 +02001859static u8 ath10k_tx_h_get_tid(struct ieee80211_hdr *hdr)
1860{
1861 if (ieee80211_is_mgmt(hdr->frame_control))
1862 return HTT_DATA_TX_EXT_TID_MGMT;
1863
1864 if (!ieee80211_is_data_qos(hdr->frame_control))
1865 return HTT_DATA_TX_EXT_TID_NON_QOS_MCAST_BCAST;
1866
1867 if (!is_unicast_ether_addr(ieee80211_get_DA(hdr)))
1868 return HTT_DATA_TX_EXT_TID_NON_QOS_MCAST_BCAST;
1869
1870 return ieee80211_get_qos_ctl(hdr)[0] & IEEE80211_QOS_CTL_TID_MASK;
1871}
1872
Michal Kazior2b37c292014-09-02 11:00:22 +03001873static u8 ath10k_tx_h_get_vdev_id(struct ath10k *ar, struct ieee80211_vif *vif)
Michal Kaziorddb6ad72013-10-02 11:03:39 +02001874{
Michal Kazior2b37c292014-09-02 11:00:22 +03001875 if (vif)
1876 return ath10k_vif_to_arvif(vif)->vdev_id;
Michal Kaziorddb6ad72013-10-02 11:03:39 +02001877
Michal Kazior1bbc0972014-04-08 09:45:47 +03001878 if (ar->monitor_started)
Michal Kaziorddb6ad72013-10-02 11:03:39 +02001879 return ar->monitor_vdev_id;
1880
Michal Kazior7aa7a722014-08-25 12:09:38 +02001881 ath10k_warn(ar, "failed to resolve vdev id\n");
Michal Kaziorddb6ad72013-10-02 11:03:39 +02001882 return 0;
1883}
1884
Michal Kazior4b604552014-07-21 21:03:09 +03001885/* HTT Tx uses Native Wifi tx mode which expects 802.11 frames without QoS
1886 * Control in the header.
Kalle Valo5e3dd152013-06-12 20:52:10 +03001887 */
Michal Kazior4b604552014-07-21 21:03:09 +03001888static void ath10k_tx_h_nwifi(struct ieee80211_hw *hw, struct sk_buff *skb)
Kalle Valo5e3dd152013-06-12 20:52:10 +03001889{
1890 struct ieee80211_hdr *hdr = (void *)skb->data;
Michal Kaziorc21c64d2014-07-21 21:03:10 +03001891 struct ath10k_skb_cb *cb = ATH10K_SKB_CB(skb);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001892 u8 *qos_ctl;
1893
1894 if (!ieee80211_is_data_qos(hdr->frame_control))
1895 return;
1896
1897 qos_ctl = ieee80211_get_qos_ctl(hdr);
Michal Kaziorba0ccd72013-07-22 14:25:28 +02001898 memmove(skb->data + IEEE80211_QOS_CTL_LEN,
1899 skb->data, (void *)qos_ctl - (void *)skb->data);
1900 skb_pull(skb, IEEE80211_QOS_CTL_LEN);
Michal Kaziorc21c64d2014-07-21 21:03:10 +03001901
1902 /* Fw/Hw generates a corrupted QoS Control Field for QoS NullFunc
1903 * frames. Powersave is handled by the fw/hw so QoS NyllFunc frames are
1904 * used only for CQM purposes (e.g. hostapd station keepalive ping) so
1905 * it is safe to downgrade to NullFunc.
1906 */
1907 if (ieee80211_is_qos_nullfunc(hdr->frame_control)) {
1908 hdr->frame_control &= ~__cpu_to_le16(IEEE80211_STYPE_QOS_DATA);
1909 cb->htt.tid = HTT_DATA_TX_EXT_TID_NON_QOS_MCAST_BCAST;
1910 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03001911}
1912
Michal Kaziorcc4827b2013-10-16 15:44:45 +03001913static void ath10k_tx_wep_key_work(struct work_struct *work)
1914{
1915 struct ath10k_vif *arvif = container_of(work, struct ath10k_vif,
1916 wep_key_work);
Michal Kazior7aa7a722014-08-25 12:09:38 +02001917 struct ath10k *ar = arvif->ar;
Michal Kaziorcc4827b2013-10-16 15:44:45 +03001918 int ret, keyidx = arvif->def_wep_key_newidx;
1919
Michal Kazior911e6c02014-05-26 12:46:03 +03001920 mutex_lock(&arvif->ar->conf_mutex);
1921
1922 if (arvif->ar->state != ATH10K_STATE_ON)
1923 goto unlock;
1924
Michal Kaziorcc4827b2013-10-16 15:44:45 +03001925 if (arvif->def_wep_key_idx == keyidx)
Michal Kazior911e6c02014-05-26 12:46:03 +03001926 goto unlock;
Michal Kaziorcc4827b2013-10-16 15:44:45 +03001927
Michal Kazior7aa7a722014-08-25 12:09:38 +02001928 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %d set keyidx %d\n",
Michal Kaziorcc4827b2013-10-16 15:44:45 +03001929 arvif->vdev_id, keyidx);
1930
1931 ret = ath10k_wmi_vdev_set_param(arvif->ar,
1932 arvif->vdev_id,
1933 arvif->ar->wmi.vdev_param->def_keyid,
1934 keyidx);
1935 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001936 ath10k_warn(ar, "failed to update wep key index for vdev %d: %d\n",
Kalle Valobe6546f2014-03-25 14:18:51 +02001937 arvif->vdev_id,
1938 ret);
Michal Kazior911e6c02014-05-26 12:46:03 +03001939 goto unlock;
Michal Kaziorcc4827b2013-10-16 15:44:45 +03001940 }
1941
1942 arvif->def_wep_key_idx = keyidx;
Michal Kazior911e6c02014-05-26 12:46:03 +03001943
1944unlock:
1945 mutex_unlock(&arvif->ar->conf_mutex);
Michal Kaziorcc4827b2013-10-16 15:44:45 +03001946}
1947
Michal Kazior4b604552014-07-21 21:03:09 +03001948static void ath10k_tx_h_update_wep_key(struct ieee80211_vif *vif,
1949 struct ieee80211_key_conf *key,
1950 struct sk_buff *skb)
Kalle Valo5e3dd152013-06-12 20:52:10 +03001951{
Kalle Valo5e3dd152013-06-12 20:52:10 +03001952 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
1953 struct ath10k *ar = arvif->ar;
1954 struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001955
Kalle Valo5e3dd152013-06-12 20:52:10 +03001956 if (!ieee80211_has_protected(hdr->frame_control))
1957 return;
1958
1959 if (!key)
1960 return;
1961
1962 if (key->cipher != WLAN_CIPHER_SUITE_WEP40 &&
1963 key->cipher != WLAN_CIPHER_SUITE_WEP104)
1964 return;
1965
Michal Kaziorcc4827b2013-10-16 15:44:45 +03001966 if (key->keyidx == arvif->def_wep_key_idx)
Kalle Valo5e3dd152013-06-12 20:52:10 +03001967 return;
1968
Michal Kaziorcc4827b2013-10-16 15:44:45 +03001969 /* FIXME: Most likely a few frames will be TXed with an old key. Simply
1970 * queueing frames until key index is updated is not an option because
1971 * sk_buff may need more processing to be done, e.g. offchannel */
1972 arvif->def_wep_key_newidx = key->keyidx;
1973 ieee80211_queue_work(ar->hw, &arvif->wep_key_work);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001974}
1975
Michal Kazior4b604552014-07-21 21:03:09 +03001976static void ath10k_tx_h_add_p2p_noa_ie(struct ath10k *ar,
1977 struct ieee80211_vif *vif,
1978 struct sk_buff *skb)
Kalle Valo5e3dd152013-06-12 20:52:10 +03001979{
1980 struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001981 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
1982
1983 /* This is case only for P2P_GO */
1984 if (arvif->vdev_type != WMI_VDEV_TYPE_AP ||
1985 arvif->vdev_subtype != WMI_VDEV_SUBTYPE_P2P_GO)
1986 return;
1987
1988 if (unlikely(ieee80211_is_probe_resp(hdr->frame_control))) {
1989 spin_lock_bh(&ar->data_lock);
1990 if (arvif->u.ap.noa_data)
1991 if (!pskb_expand_head(skb, 0, arvif->u.ap.noa_len,
1992 GFP_ATOMIC))
1993 memcpy(skb_put(skb, arvif->u.ap.noa_len),
1994 arvif->u.ap.noa_data,
1995 arvif->u.ap.noa_len);
1996 spin_unlock_bh(&ar->data_lock);
1997 }
1998}
1999
2000static void ath10k_tx_htt(struct ath10k *ar, struct sk_buff *skb)
2001{
2002 struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data;
Bartosz Markowski5e00d312013-09-26 17:47:12 +02002003 int ret = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002004
Michal Kazior961d4c32013-08-09 10:13:34 +02002005 if (ar->htt.target_version_major >= 3) {
2006 /* Since HTT 3.0 there is no separate mgmt tx command */
2007 ret = ath10k_htt_tx(&ar->htt, skb);
2008 goto exit;
2009 }
2010
Bartosz Markowski5e00d312013-09-26 17:47:12 +02002011 if (ieee80211_is_mgmt(hdr->frame_control)) {
2012 if (test_bit(ATH10K_FW_FEATURE_HAS_WMI_MGMT_TX,
2013 ar->fw_features)) {
2014 if (skb_queue_len(&ar->wmi_mgmt_tx_queue) >=
2015 ATH10K_MAX_NUM_MGMT_PENDING) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002016 ath10k_warn(ar, "reached WMI management transmit queue limit\n");
Bartosz Markowski5e00d312013-09-26 17:47:12 +02002017 ret = -EBUSY;
2018 goto exit;
2019 }
2020
2021 skb_queue_tail(&ar->wmi_mgmt_tx_queue, skb);
2022 ieee80211_queue_work(ar->hw, &ar->wmi_mgmt_tx_work);
2023 } else {
2024 ret = ath10k_htt_mgmt_tx(&ar->htt, skb);
2025 }
2026 } else if (!test_bit(ATH10K_FW_FEATURE_HAS_WMI_MGMT_TX,
2027 ar->fw_features) &&
2028 ieee80211_is_nullfunc(hdr->frame_control)) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03002029 /* FW does not report tx status properly for NullFunc frames
2030 * unless they are sent through mgmt tx path. mac80211 sends
Bartosz Markowski5e00d312013-09-26 17:47:12 +02002031 * those frames when it detects link/beacon loss and depends
2032 * on the tx status to be correct. */
Michal Kazioredb82362013-07-05 16:15:14 +03002033 ret = ath10k_htt_mgmt_tx(&ar->htt, skb);
Bartosz Markowski5e00d312013-09-26 17:47:12 +02002034 } else {
Michal Kazioredb82362013-07-05 16:15:14 +03002035 ret = ath10k_htt_tx(&ar->htt, skb);
Bartosz Markowski5e00d312013-09-26 17:47:12 +02002036 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002037
Michal Kazior961d4c32013-08-09 10:13:34 +02002038exit:
Kalle Valo5e3dd152013-06-12 20:52:10 +03002039 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002040 ath10k_warn(ar, "failed to transmit packet, dropping: %d\n",
2041 ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002042 ieee80211_free_txskb(ar->hw, skb);
2043 }
2044}
2045
2046void ath10k_offchan_tx_purge(struct ath10k *ar)
2047{
2048 struct sk_buff *skb;
2049
2050 for (;;) {
2051 skb = skb_dequeue(&ar->offchan_tx_queue);
2052 if (!skb)
2053 break;
2054
2055 ieee80211_free_txskb(ar->hw, skb);
2056 }
2057}
2058
2059void ath10k_offchan_tx_work(struct work_struct *work)
2060{
2061 struct ath10k *ar = container_of(work, struct ath10k, offchan_tx_work);
2062 struct ath10k_peer *peer;
2063 struct ieee80211_hdr *hdr;
2064 struct sk_buff *skb;
2065 const u8 *peer_addr;
2066 int vdev_id;
2067 int ret;
2068
2069 /* FW requirement: We must create a peer before FW will send out
2070 * an offchannel frame. Otherwise the frame will be stuck and
2071 * never transmitted. We delete the peer upon tx completion.
2072 * It is unlikely that a peer for offchannel tx will already be
2073 * present. However it may be in some rare cases so account for that.
2074 * Otherwise we might remove a legitimate peer and break stuff. */
2075
2076 for (;;) {
2077 skb = skb_dequeue(&ar->offchan_tx_queue);
2078 if (!skb)
2079 break;
2080
2081 mutex_lock(&ar->conf_mutex);
2082
Michal Kazior7aa7a722014-08-25 12:09:38 +02002083 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac offchannel skb %p\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03002084 skb);
2085
2086 hdr = (struct ieee80211_hdr *)skb->data;
2087 peer_addr = ieee80211_get_DA(hdr);
Bartosz Markowski5e00d312013-09-26 17:47:12 +02002088 vdev_id = ATH10K_SKB_CB(skb)->vdev_id;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002089
2090 spin_lock_bh(&ar->data_lock);
2091 peer = ath10k_peer_find(ar, vdev_id, peer_addr);
2092 spin_unlock_bh(&ar->data_lock);
2093
2094 if (peer)
Kalle Valo60c3daa2013-09-08 17:56:07 +03002095 /* FIXME: should this use ath10k_warn()? */
Michal Kazior7aa7a722014-08-25 12:09:38 +02002096 ath10k_dbg(ar, ATH10K_DBG_MAC, "peer %pM on vdev %d already present\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03002097 peer_addr, vdev_id);
2098
2099 if (!peer) {
2100 ret = ath10k_peer_create(ar, vdev_id, peer_addr);
2101 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02002102 ath10k_warn(ar, "failed to create peer %pM on vdev %d: %d\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03002103 peer_addr, vdev_id, ret);
2104 }
2105
2106 spin_lock_bh(&ar->data_lock);
Wolfram Sang16735d02013-11-14 14:32:02 -08002107 reinit_completion(&ar->offchan_tx_completed);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002108 ar->offchan_tx_skb = skb;
2109 spin_unlock_bh(&ar->data_lock);
2110
2111 ath10k_tx_htt(ar, skb);
2112
2113 ret = wait_for_completion_timeout(&ar->offchan_tx_completed,
2114 3 * HZ);
2115 if (ret <= 0)
Michal Kazior7aa7a722014-08-25 12:09:38 +02002116 ath10k_warn(ar, "timed out waiting for offchannel skb %p\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03002117 skb);
2118
2119 if (!peer) {
2120 ret = ath10k_peer_delete(ar, vdev_id, peer_addr);
2121 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02002122 ath10k_warn(ar, "failed to delete peer %pM on vdev %d: %d\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03002123 peer_addr, vdev_id, ret);
2124 }
2125
2126 mutex_unlock(&ar->conf_mutex);
2127 }
2128}
2129
Bartosz Markowski5e00d312013-09-26 17:47:12 +02002130void ath10k_mgmt_over_wmi_tx_purge(struct ath10k *ar)
2131{
2132 struct sk_buff *skb;
2133
2134 for (;;) {
2135 skb = skb_dequeue(&ar->wmi_mgmt_tx_queue);
2136 if (!skb)
2137 break;
2138
2139 ieee80211_free_txskb(ar->hw, skb);
2140 }
2141}
2142
2143void ath10k_mgmt_over_wmi_tx_work(struct work_struct *work)
2144{
2145 struct ath10k *ar = container_of(work, struct ath10k, wmi_mgmt_tx_work);
2146 struct sk_buff *skb;
2147 int ret;
2148
2149 for (;;) {
2150 skb = skb_dequeue(&ar->wmi_mgmt_tx_queue);
2151 if (!skb)
2152 break;
2153
2154 ret = ath10k_wmi_mgmt_tx(ar, skb);
Michal Kazior5fb5e412013-10-28 07:18:13 +01002155 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002156 ath10k_warn(ar, "failed to transmit management frame via WMI: %d\n",
Kalle Valobe6546f2014-03-25 14:18:51 +02002157 ret);
Michal Kazior5fb5e412013-10-28 07:18:13 +01002158 ieee80211_free_txskb(ar->hw, skb);
2159 }
Bartosz Markowski5e00d312013-09-26 17:47:12 +02002160 }
2161}
2162
Kalle Valo5e3dd152013-06-12 20:52:10 +03002163/************/
2164/* Scanning */
2165/************/
2166
Michal Kazior5c81c7f2014-08-05 14:54:44 +02002167void __ath10k_scan_finish(struct ath10k *ar)
Kalle Valo5e3dd152013-06-12 20:52:10 +03002168{
Michal Kazior5c81c7f2014-08-05 14:54:44 +02002169 lockdep_assert_held(&ar->data_lock);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002170
Michal Kazior5c81c7f2014-08-05 14:54:44 +02002171 switch (ar->scan.state) {
2172 case ATH10K_SCAN_IDLE:
2173 break;
2174 case ATH10K_SCAN_RUNNING:
2175 case ATH10K_SCAN_ABORTING:
2176 if (ar->scan.is_roc)
2177 ieee80211_remain_on_channel_expired(ar->hw);
2178 else
2179 ieee80211_scan_completed(ar->hw,
2180 (ar->scan.state ==
2181 ATH10K_SCAN_ABORTING));
2182 /* fall through */
2183 case ATH10K_SCAN_STARTING:
2184 ar->scan.state = ATH10K_SCAN_IDLE;
2185 ar->scan_channel = NULL;
2186 ath10k_offchan_tx_purge(ar);
2187 cancel_delayed_work(&ar->scan.timeout);
2188 complete_all(&ar->scan.completed);
2189 break;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002190 }
Michal Kazior5c81c7f2014-08-05 14:54:44 +02002191}
Kalle Valo5e3dd152013-06-12 20:52:10 +03002192
Michal Kazior5c81c7f2014-08-05 14:54:44 +02002193void ath10k_scan_finish(struct ath10k *ar)
2194{
2195 spin_lock_bh(&ar->data_lock);
2196 __ath10k_scan_finish(ar);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002197 spin_unlock_bh(&ar->data_lock);
2198}
2199
Michal Kazior5c81c7f2014-08-05 14:54:44 +02002200static int ath10k_scan_stop(struct ath10k *ar)
Kalle Valo5e3dd152013-06-12 20:52:10 +03002201{
2202 struct wmi_stop_scan_arg arg = {
2203 .req_id = 1, /* FIXME */
2204 .req_type = WMI_SCAN_STOP_ONE,
2205 .u.scan_id = ATH10K_SCAN_ID,
2206 };
2207 int ret;
2208
2209 lockdep_assert_held(&ar->conf_mutex);
2210
Kalle Valo5e3dd152013-06-12 20:52:10 +03002211 ret = ath10k_wmi_stop_scan(ar, &arg);
2212 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002213 ath10k_warn(ar, "failed to stop wmi scan: %d\n", ret);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02002214 goto out;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002215 }
2216
Kalle Valo5e3dd152013-06-12 20:52:10 +03002217 ret = wait_for_completion_timeout(&ar->scan.completed, 3*HZ);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02002218 if (ret == 0) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002219 ath10k_warn(ar, "failed to receive scan abortion completion: timed out\n");
Kalle Valo5e3dd152013-06-12 20:52:10 +03002220 ret = -ETIMEDOUT;
Michal Kazior5c81c7f2014-08-05 14:54:44 +02002221 } else if (ret > 0) {
2222 ret = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002223 }
Michal Kazior5c81c7f2014-08-05 14:54:44 +02002224
2225out:
2226 /* Scan state should be updated upon scan completion but in case
2227 * firmware fails to deliver the event (for whatever reason) it is
2228 * desired to clean up scan state anyway. Firmware may have just
2229 * dropped the scan completion event delivery due to transport pipe
2230 * being overflown with data and/or it can recover on its own before
2231 * next scan request is submitted.
2232 */
2233 spin_lock_bh(&ar->data_lock);
2234 if (ar->scan.state != ATH10K_SCAN_IDLE)
2235 __ath10k_scan_finish(ar);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002236 spin_unlock_bh(&ar->data_lock);
2237
2238 return ret;
2239}
2240
Michal Kazior5c81c7f2014-08-05 14:54:44 +02002241static void ath10k_scan_abort(struct ath10k *ar)
2242{
2243 int ret;
2244
2245 lockdep_assert_held(&ar->conf_mutex);
2246
2247 spin_lock_bh(&ar->data_lock);
2248
2249 switch (ar->scan.state) {
2250 case ATH10K_SCAN_IDLE:
2251 /* This can happen if timeout worker kicked in and called
2252 * abortion while scan completion was being processed.
2253 */
2254 break;
2255 case ATH10K_SCAN_STARTING:
2256 case ATH10K_SCAN_ABORTING:
Michal Kazior7aa7a722014-08-25 12:09:38 +02002257 ath10k_warn(ar, "refusing scan abortion due to invalid scan state: %s (%d)\n",
Michal Kazior5c81c7f2014-08-05 14:54:44 +02002258 ath10k_scan_state_str(ar->scan.state),
2259 ar->scan.state);
2260 break;
2261 case ATH10K_SCAN_RUNNING:
2262 ar->scan.state = ATH10K_SCAN_ABORTING;
2263 spin_unlock_bh(&ar->data_lock);
2264
2265 ret = ath10k_scan_stop(ar);
2266 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02002267 ath10k_warn(ar, "failed to abort scan: %d\n", ret);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02002268
2269 spin_lock_bh(&ar->data_lock);
2270 break;
2271 }
2272
2273 spin_unlock_bh(&ar->data_lock);
2274}
2275
2276void ath10k_scan_timeout_work(struct work_struct *work)
2277{
2278 struct ath10k *ar = container_of(work, struct ath10k,
2279 scan.timeout.work);
2280
2281 mutex_lock(&ar->conf_mutex);
2282 ath10k_scan_abort(ar);
2283 mutex_unlock(&ar->conf_mutex);
2284}
2285
Kalle Valo5e3dd152013-06-12 20:52:10 +03002286static int ath10k_start_scan(struct ath10k *ar,
2287 const struct wmi_start_scan_arg *arg)
2288{
2289 int ret;
2290
2291 lockdep_assert_held(&ar->conf_mutex);
2292
2293 ret = ath10k_wmi_start_scan(ar, arg);
2294 if (ret)
2295 return ret;
2296
Kalle Valo5e3dd152013-06-12 20:52:10 +03002297 ret = wait_for_completion_timeout(&ar->scan.started, 1*HZ);
2298 if (ret == 0) {
Michal Kazior5c81c7f2014-08-05 14:54:44 +02002299 ret = ath10k_scan_stop(ar);
2300 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02002301 ath10k_warn(ar, "failed to stop scan: %d\n", ret);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02002302
2303 return -ETIMEDOUT;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002304 }
2305
Michal Kazior5c81c7f2014-08-05 14:54:44 +02002306 /* Add a 200ms margin to account for event/command processing */
2307 ieee80211_queue_delayed_work(ar->hw, &ar->scan.timeout,
2308 msecs_to_jiffies(arg->max_scan_time+200));
Kalle Valo5e3dd152013-06-12 20:52:10 +03002309 return 0;
2310}
2311
2312/**********************/
2313/* mac80211 callbacks */
2314/**********************/
2315
2316static void ath10k_tx(struct ieee80211_hw *hw,
2317 struct ieee80211_tx_control *control,
2318 struct sk_buff *skb)
2319{
Kalle Valo5e3dd152013-06-12 20:52:10 +03002320 struct ath10k *ar = hw->priv;
Michal Kazior4b604552014-07-21 21:03:09 +03002321 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
2322 struct ieee80211_vif *vif = info->control.vif;
2323 struct ieee80211_key_conf *key = info->control.hw_key;
2324 struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002325
2326 /* We should disable CCK RATE due to P2P */
2327 if (info->flags & IEEE80211_TX_CTL_NO_CCK_RATE)
Michal Kazior7aa7a722014-08-25 12:09:38 +02002328 ath10k_dbg(ar, ATH10K_DBG_MAC, "IEEE80211_TX_CTL_NO_CCK_RATE\n");
Kalle Valo5e3dd152013-06-12 20:52:10 +03002329
Michal Kazior4b604552014-07-21 21:03:09 +03002330 ATH10K_SKB_CB(skb)->htt.is_offchan = false;
2331 ATH10K_SKB_CB(skb)->htt.tid = ath10k_tx_h_get_tid(hdr);
Michal Kazior2b37c292014-09-02 11:00:22 +03002332 ATH10K_SKB_CB(skb)->vdev_id = ath10k_tx_h_get_vdev_id(ar, vif);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002333
Michal Kaziorcf84bd42013-07-16 11:04:54 +02002334 /* it makes no sense to process injected frames like that */
Michal Kazior4b604552014-07-21 21:03:09 +03002335 if (vif && vif->type != NL80211_IFTYPE_MONITOR) {
2336 ath10k_tx_h_nwifi(hw, skb);
2337 ath10k_tx_h_update_wep_key(vif, key, skb);
2338 ath10k_tx_h_add_p2p_noa_ie(ar, vif, skb);
2339 ath10k_tx_h_seq_no(vif, skb);
Michal Kaziorcf84bd42013-07-16 11:04:54 +02002340 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002341
Kalle Valo5e3dd152013-06-12 20:52:10 +03002342 if (info->flags & IEEE80211_TX_CTL_TX_OFFCHAN) {
2343 spin_lock_bh(&ar->data_lock);
2344 ATH10K_SKB_CB(skb)->htt.is_offchan = true;
Bartosz Markowski5e00d312013-09-26 17:47:12 +02002345 ATH10K_SKB_CB(skb)->vdev_id = ar->scan.vdev_id;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002346 spin_unlock_bh(&ar->data_lock);
2347
Michal Kazior7aa7a722014-08-25 12:09:38 +02002348 ath10k_dbg(ar, ATH10K_DBG_MAC, "queued offchannel skb %p\n",
2349 skb);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002350
2351 skb_queue_tail(&ar->offchan_tx_queue, skb);
2352 ieee80211_queue_work(hw, &ar->offchan_tx_work);
2353 return;
2354 }
2355
2356 ath10k_tx_htt(ar, skb);
2357}
2358
Michal Kaziorbca7baf2014-05-26 12:46:03 +03002359/* Must not be called with conf_mutex held as workers can use that also. */
Michal Kazior7962b0d2014-10-28 10:34:38 +01002360void ath10k_drain_tx(struct ath10k *ar)
Michal Kaziorbca7baf2014-05-26 12:46:03 +03002361{
2362 /* make sure rcu-protected mac80211 tx path itself is drained */
2363 synchronize_net();
2364
2365 ath10k_offchan_tx_purge(ar);
2366 ath10k_mgmt_over_wmi_tx_purge(ar);
2367
2368 cancel_work_sync(&ar->offchan_tx_work);
2369 cancel_work_sync(&ar->wmi_mgmt_tx_work);
2370}
2371
Michal Kazioraffd3212013-07-16 09:54:35 +02002372void ath10k_halt(struct ath10k *ar)
Michal Kazior818bdd12013-07-16 09:38:57 +02002373{
Michal Kaziord9bc4b92014-04-23 19:30:06 +03002374 struct ath10k_vif *arvif;
2375
Michal Kazior818bdd12013-07-16 09:38:57 +02002376 lockdep_assert_held(&ar->conf_mutex);
2377
Michal Kazior19337472014-08-28 12:58:16 +02002378 clear_bit(ATH10K_CAC_RUNNING, &ar->dev_flags);
2379 ar->filter_flags = 0;
2380 ar->monitor = false;
2381
2382 if (ar->monitor_started)
Michal Kazior1bbc0972014-04-08 09:45:47 +03002383 ath10k_monitor_stop(ar);
Michal Kazior19337472014-08-28 12:58:16 +02002384
2385 ar->monitor_started = false;
Michal Kazior1bbc0972014-04-08 09:45:47 +03002386
Michal Kazior5c81c7f2014-08-05 14:54:44 +02002387 ath10k_scan_finish(ar);
Michal Kazior818bdd12013-07-16 09:38:57 +02002388 ath10k_peer_cleanup_all(ar);
2389 ath10k_core_stop(ar);
2390 ath10k_hif_power_down(ar);
2391
2392 spin_lock_bh(&ar->data_lock);
Michal Kazior64badcb2014-09-18 11:18:02 +03002393 list_for_each_entry(arvif, &ar->arvifs, list)
2394 ath10k_mac_vif_beacon_cleanup(arvif);
Michal Kazior818bdd12013-07-16 09:38:57 +02002395 spin_unlock_bh(&ar->data_lock);
2396}
2397
Ben Greear46acf7b2014-05-16 17:15:38 +03002398static int ath10k_get_antenna(struct ieee80211_hw *hw, u32 *tx_ant, u32 *rx_ant)
2399{
2400 struct ath10k *ar = hw->priv;
2401
2402 mutex_lock(&ar->conf_mutex);
2403
2404 if (ar->cfg_tx_chainmask) {
2405 *tx_ant = ar->cfg_tx_chainmask;
2406 *rx_ant = ar->cfg_rx_chainmask;
2407 } else {
2408 *tx_ant = ar->supp_tx_chainmask;
2409 *rx_ant = ar->supp_rx_chainmask;
2410 }
2411
2412 mutex_unlock(&ar->conf_mutex);
2413
2414 return 0;
2415}
2416
Ben Greear5572a952014-11-24 16:22:10 +02002417static void ath10k_check_chain_mask(struct ath10k *ar, u32 cm, const char *dbg)
2418{
2419 /* It is not clear that allowing gaps in chainmask
2420 * is helpful. Probably it will not do what user
2421 * is hoping for, so warn in that case.
2422 */
2423 if (cm == 15 || cm == 7 || cm == 3 || cm == 1 || cm == 0)
2424 return;
2425
2426 ath10k_warn(ar, "mac %s antenna chainmask may be invalid: 0x%x. Suggested values: 15, 7, 3, 1 or 0.\n",
2427 dbg, cm);
2428}
2429
Ben Greear46acf7b2014-05-16 17:15:38 +03002430static int __ath10k_set_antenna(struct ath10k *ar, u32 tx_ant, u32 rx_ant)
2431{
2432 int ret;
2433
2434 lockdep_assert_held(&ar->conf_mutex);
2435
Ben Greear5572a952014-11-24 16:22:10 +02002436 ath10k_check_chain_mask(ar, tx_ant, "tx");
2437 ath10k_check_chain_mask(ar, rx_ant, "rx");
2438
Ben Greear46acf7b2014-05-16 17:15:38 +03002439 ar->cfg_tx_chainmask = tx_ant;
2440 ar->cfg_rx_chainmask = rx_ant;
2441
2442 if ((ar->state != ATH10K_STATE_ON) &&
2443 (ar->state != ATH10K_STATE_RESTARTED))
2444 return 0;
2445
2446 ret = ath10k_wmi_pdev_set_param(ar, ar->wmi.pdev_param->tx_chain_mask,
2447 tx_ant);
2448 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002449 ath10k_warn(ar, "failed to set tx-chainmask: %d, req 0x%x\n",
Ben Greear46acf7b2014-05-16 17:15:38 +03002450 ret, tx_ant);
2451 return ret;
2452 }
2453
2454 ret = ath10k_wmi_pdev_set_param(ar, ar->wmi.pdev_param->rx_chain_mask,
2455 rx_ant);
2456 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002457 ath10k_warn(ar, "failed to set rx-chainmask: %d, req 0x%x\n",
Ben Greear46acf7b2014-05-16 17:15:38 +03002458 ret, rx_ant);
2459 return ret;
2460 }
2461
2462 return 0;
2463}
2464
2465static int ath10k_set_antenna(struct ieee80211_hw *hw, u32 tx_ant, u32 rx_ant)
2466{
2467 struct ath10k *ar = hw->priv;
2468 int ret;
2469
2470 mutex_lock(&ar->conf_mutex);
2471 ret = __ath10k_set_antenna(ar, tx_ant, rx_ant);
2472 mutex_unlock(&ar->conf_mutex);
2473 return ret;
2474}
2475
Kalle Valo5e3dd152013-06-12 20:52:10 +03002476static int ath10k_start(struct ieee80211_hw *hw)
2477{
2478 struct ath10k *ar = hw->priv;
Michal Kazior818bdd12013-07-16 09:38:57 +02002479 int ret = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002480
Michal Kaziorbca7baf2014-05-26 12:46:03 +03002481 /*
2482 * This makes sense only when restarting hw. It is harmless to call
2483 * uncoditionally. This is necessary to make sure no HTT/WMI tx
2484 * commands will be submitted while restarting.
2485 */
2486 ath10k_drain_tx(ar);
2487
Michal Kazior548db542013-07-05 16:15:15 +03002488 mutex_lock(&ar->conf_mutex);
2489
Michal Kaziorc5058f52014-05-26 12:46:03 +03002490 switch (ar->state) {
2491 case ATH10K_STATE_OFF:
2492 ar->state = ATH10K_STATE_ON;
2493 break;
2494 case ATH10K_STATE_RESTARTING:
2495 ath10k_halt(ar);
2496 ar->state = ATH10K_STATE_RESTARTED;
2497 break;
2498 case ATH10K_STATE_ON:
2499 case ATH10K_STATE_RESTARTED:
2500 case ATH10K_STATE_WEDGED:
2501 WARN_ON(1);
Michal Kazior818bdd12013-07-16 09:38:57 +02002502 ret = -EINVAL;
Michal Kaziorae254432014-05-26 12:46:02 +03002503 goto err;
Kalle Valo43d2a302014-09-10 18:23:30 +03002504 case ATH10K_STATE_UTF:
2505 ret = -EBUSY;
2506 goto err;
Michal Kazior818bdd12013-07-16 09:38:57 +02002507 }
2508
2509 ret = ath10k_hif_power_up(ar);
2510 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002511 ath10k_err(ar, "Could not init hif: %d\n", ret);
Michal Kaziorae254432014-05-26 12:46:02 +03002512 goto err_off;
Michal Kazior818bdd12013-07-16 09:38:57 +02002513 }
2514
Kalle Valo43d2a302014-09-10 18:23:30 +03002515 ret = ath10k_core_start(ar, ATH10K_FIRMWARE_MODE_NORMAL);
Michal Kazior818bdd12013-07-16 09:38:57 +02002516 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002517 ath10k_err(ar, "Could not init core: %d\n", ret);
Michal Kaziorae254432014-05-26 12:46:02 +03002518 goto err_power_down;
Michal Kazior818bdd12013-07-16 09:38:57 +02002519 }
2520
Bartosz Markowski226a3392013-09-26 17:47:16 +02002521 ret = ath10k_wmi_pdev_set_param(ar, ar->wmi.pdev_param->pmf_qos, 1);
Michal Kaziorae254432014-05-26 12:46:02 +03002522 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002523 ath10k_warn(ar, "failed to enable PMF QOS: %d\n", ret);
Michal Kaziorae254432014-05-26 12:46:02 +03002524 goto err_core_stop;
2525 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002526
Michal Kaziorc4dd0d02013-11-13 11:05:10 +01002527 ret = ath10k_wmi_pdev_set_param(ar, ar->wmi.pdev_param->dynamic_bw, 1);
Michal Kaziorae254432014-05-26 12:46:02 +03002528 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002529 ath10k_warn(ar, "failed to enable dynamic BW: %d\n", ret);
Michal Kaziorae254432014-05-26 12:46:02 +03002530 goto err_core_stop;
2531 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002532
Ben Greear46acf7b2014-05-16 17:15:38 +03002533 if (ar->cfg_tx_chainmask)
2534 __ath10k_set_antenna(ar, ar->cfg_tx_chainmask,
2535 ar->cfg_rx_chainmask);
2536
Marek Puzyniakab6258e2014-01-29 15:03:31 +02002537 /*
2538 * By default FW set ARP frames ac to voice (6). In that case ARP
2539 * exchange is not working properly for UAPSD enabled AP. ARP requests
2540 * which arrives with access category 0 are processed by network stack
2541 * and send back with access category 0, but FW changes access category
2542 * to 6. Set ARP frames access category to best effort (0) solves
2543 * this problem.
2544 */
2545
2546 ret = ath10k_wmi_pdev_set_param(ar,
2547 ar->wmi.pdev_param->arp_ac_override, 0);
2548 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002549 ath10k_warn(ar, "failed to set arp ac override parameter: %d\n",
Marek Puzyniakab6258e2014-01-29 15:03:31 +02002550 ret);
Michal Kaziorae254432014-05-26 12:46:02 +03002551 goto err_core_stop;
Marek Puzyniakab6258e2014-01-29 15:03:31 +02002552 }
2553
Michal Kaziord6500972014-04-08 09:56:09 +03002554 ar->num_started_vdevs = 0;
Michal Kaziorf7843d72013-07-16 09:38:52 +02002555 ath10k_regd_update(ar);
2556
Simon Wunderlich855aed12014-08-02 09:12:54 +03002557 ath10k_spectral_start(ar);
2558
Michal Kaziorae254432014-05-26 12:46:02 +03002559 mutex_unlock(&ar->conf_mutex);
2560 return 0;
2561
2562err_core_stop:
2563 ath10k_core_stop(ar);
2564
2565err_power_down:
2566 ath10k_hif_power_down(ar);
2567
2568err_off:
2569 ar->state = ATH10K_STATE_OFF;
2570
2571err:
Michal Kazior548db542013-07-05 16:15:15 +03002572 mutex_unlock(&ar->conf_mutex);
Michal Kaziorc60bdd82014-01-29 07:26:31 +01002573 return ret;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002574}
2575
2576static void ath10k_stop(struct ieee80211_hw *hw)
2577{
2578 struct ath10k *ar = hw->priv;
2579
Michal Kaziorbca7baf2014-05-26 12:46:03 +03002580 ath10k_drain_tx(ar);
2581
Michal Kazior548db542013-07-05 16:15:15 +03002582 mutex_lock(&ar->conf_mutex);
Michal Kaziorc5058f52014-05-26 12:46:03 +03002583 if (ar->state != ATH10K_STATE_OFF) {
Michal Kazior818bdd12013-07-16 09:38:57 +02002584 ath10k_halt(ar);
Michal Kaziorc5058f52014-05-26 12:46:03 +03002585 ar->state = ATH10K_STATE_OFF;
2586 }
Michal Kazior548db542013-07-05 16:15:15 +03002587 mutex_unlock(&ar->conf_mutex);
2588
Michal Kazior5c81c7f2014-08-05 14:54:44 +02002589 cancel_delayed_work_sync(&ar->scan.timeout);
Michal Kazioraffd3212013-07-16 09:54:35 +02002590 cancel_work_sync(&ar->restart_work);
2591}
2592
Michal Kaziorad088bf2013-10-16 15:44:46 +03002593static int ath10k_config_ps(struct ath10k *ar)
Michal Kazioraffd3212013-07-16 09:54:35 +02002594{
Michal Kaziorad088bf2013-10-16 15:44:46 +03002595 struct ath10k_vif *arvif;
2596 int ret = 0;
Michal Kazioraffd3212013-07-16 09:54:35 +02002597
2598 lockdep_assert_held(&ar->conf_mutex);
2599
Michal Kaziorad088bf2013-10-16 15:44:46 +03002600 list_for_each_entry(arvif, &ar->arvifs, list) {
2601 ret = ath10k_mac_vif_setup_ps(arvif);
2602 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002603 ath10k_warn(ar, "failed to setup powersave: %d\n", ret);
Michal Kaziorad088bf2013-10-16 15:44:46 +03002604 break;
2605 }
2606 }
Michal Kazioraffd3212013-07-16 09:54:35 +02002607
Michal Kaziorad088bf2013-10-16 15:44:46 +03002608 return ret;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002609}
2610
Michal Kaziorc930f742014-01-23 11:38:25 +01002611static const char *chandef_get_width(enum nl80211_chan_width width)
2612{
2613 switch (width) {
2614 case NL80211_CHAN_WIDTH_20_NOHT:
2615 return "20 (noht)";
2616 case NL80211_CHAN_WIDTH_20:
2617 return "20";
2618 case NL80211_CHAN_WIDTH_40:
2619 return "40";
2620 case NL80211_CHAN_WIDTH_80:
2621 return "80";
2622 case NL80211_CHAN_WIDTH_80P80:
2623 return "80+80";
2624 case NL80211_CHAN_WIDTH_160:
2625 return "160";
2626 case NL80211_CHAN_WIDTH_5:
2627 return "5";
2628 case NL80211_CHAN_WIDTH_10:
2629 return "10";
2630 }
2631 return "?";
2632}
2633
2634static void ath10k_config_chan(struct ath10k *ar)
2635{
2636 struct ath10k_vif *arvif;
Michal Kaziorc930f742014-01-23 11:38:25 +01002637 int ret;
2638
2639 lockdep_assert_held(&ar->conf_mutex);
2640
Michal Kazior7aa7a722014-08-25 12:09:38 +02002641 ath10k_dbg(ar, ATH10K_DBG_MAC,
Michal Kaziorc930f742014-01-23 11:38:25 +01002642 "mac config channel to %dMHz (cf1 %dMHz cf2 %dMHz width %s)\n",
2643 ar->chandef.chan->center_freq,
2644 ar->chandef.center_freq1,
2645 ar->chandef.center_freq2,
2646 chandef_get_width(ar->chandef.width));
2647
2648 /* First stop monitor interface. Some FW versions crash if there's a
2649 * lone monitor interface. */
Michal Kazior1bbc0972014-04-08 09:45:47 +03002650 if (ar->monitor_started)
Michal Kazior19337472014-08-28 12:58:16 +02002651 ath10k_monitor_stop(ar);
Michal Kaziorc930f742014-01-23 11:38:25 +01002652
2653 list_for_each_entry(arvif, &ar->arvifs, list) {
2654 if (!arvif->is_started)
2655 continue;
2656
Michal Kaziordc55e302014-07-29 12:53:36 +03002657 if (!arvif->is_up)
2658 continue;
2659
Michal Kaziorc930f742014-01-23 11:38:25 +01002660 if (arvif->vdev_type == WMI_VDEV_TYPE_MONITOR)
2661 continue;
2662
Michal Kaziordc55e302014-07-29 12:53:36 +03002663 ret = ath10k_wmi_vdev_down(ar, arvif->vdev_id);
Michal Kaziorc930f742014-01-23 11:38:25 +01002664 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002665 ath10k_warn(ar, "failed to down vdev %d: %d\n",
Michal Kaziorc930f742014-01-23 11:38:25 +01002666 arvif->vdev_id, ret);
2667 continue;
2668 }
2669 }
2670
Michal Kaziordc55e302014-07-29 12:53:36 +03002671 /* all vdevs are downed now - attempt to restart and re-up them */
Michal Kaziorc930f742014-01-23 11:38:25 +01002672
2673 list_for_each_entry(arvif, &ar->arvifs, list) {
2674 if (!arvif->is_started)
2675 continue;
2676
2677 if (arvif->vdev_type == WMI_VDEV_TYPE_MONITOR)
2678 continue;
2679
Michal Kaziordc55e302014-07-29 12:53:36 +03002680 ret = ath10k_vdev_restart(arvif);
Michal Kaziorc930f742014-01-23 11:38:25 +01002681 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002682 ath10k_warn(ar, "failed to restart vdev %d: %d\n",
Michal Kaziorc930f742014-01-23 11:38:25 +01002683 arvif->vdev_id, ret);
2684 continue;
2685 }
2686
2687 if (!arvif->is_up)
2688 continue;
2689
2690 ret = ath10k_wmi_vdev_up(arvif->ar, arvif->vdev_id, arvif->aid,
2691 arvif->bssid);
2692 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002693 ath10k_warn(ar, "failed to bring vdev up %d: %d\n",
Michal Kaziorc930f742014-01-23 11:38:25 +01002694 arvif->vdev_id, ret);
2695 continue;
2696 }
2697 }
2698
Michal Kazior19337472014-08-28 12:58:16 +02002699 ath10k_monitor_recalc(ar);
Michal Kaziorc930f742014-01-23 11:38:25 +01002700}
2701
Michal Kazior7d9d5582014-10-21 10:40:15 +03002702static int ath10k_mac_txpower_setup(struct ath10k *ar, int txpower)
2703{
2704 int ret;
2705 u32 param;
2706
2707 lockdep_assert_held(&ar->conf_mutex);
2708
2709 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac txpower %d\n", txpower);
2710
2711 param = ar->wmi.pdev_param->txpower_limit2g;
2712 ret = ath10k_wmi_pdev_set_param(ar, param, txpower * 2);
2713 if (ret) {
2714 ath10k_warn(ar, "failed to set 2g txpower %d: %d\n",
2715 txpower, ret);
2716 return ret;
2717 }
2718
2719 param = ar->wmi.pdev_param->txpower_limit5g;
2720 ret = ath10k_wmi_pdev_set_param(ar, param, txpower * 2);
2721 if (ret) {
2722 ath10k_warn(ar, "failed to set 5g txpower %d: %d\n",
2723 txpower, ret);
2724 return ret;
2725 }
2726
2727 return 0;
2728}
2729
2730static int ath10k_mac_txpower_recalc(struct ath10k *ar)
2731{
2732 struct ath10k_vif *arvif;
2733 int ret, txpower = -1;
2734
2735 lockdep_assert_held(&ar->conf_mutex);
2736
2737 list_for_each_entry(arvif, &ar->arvifs, list) {
2738 WARN_ON(arvif->txpower < 0);
2739
2740 if (txpower == -1)
2741 txpower = arvif->txpower;
2742 else
2743 txpower = min(txpower, arvif->txpower);
2744 }
2745
2746 if (WARN_ON(txpower == -1))
2747 return -EINVAL;
2748
2749 ret = ath10k_mac_txpower_setup(ar, txpower);
2750 if (ret) {
2751 ath10k_warn(ar, "failed to setup tx power %d: %d\n",
2752 txpower, ret);
2753 return ret;
2754 }
2755
2756 return 0;
2757}
2758
Kalle Valo5e3dd152013-06-12 20:52:10 +03002759static int ath10k_config(struct ieee80211_hw *hw, u32 changed)
2760{
Kalle Valo5e3dd152013-06-12 20:52:10 +03002761 struct ath10k *ar = hw->priv;
2762 struct ieee80211_conf *conf = &hw->conf;
2763 int ret = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002764
2765 mutex_lock(&ar->conf_mutex);
2766
2767 if (changed & IEEE80211_CONF_CHANGE_CHANNEL) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002768 ath10k_dbg(ar, ATH10K_DBG_MAC,
Michal Kaziord6500972014-04-08 09:56:09 +03002769 "mac config channel %dMHz flags 0x%x radar %d\n",
Marek Puzyniake8a50f82013-11-20 09:59:47 +02002770 conf->chandef.chan->center_freq,
Michal Kaziord6500972014-04-08 09:56:09 +03002771 conf->chandef.chan->flags,
2772 conf->radar_enabled);
Marek Puzyniake8a50f82013-11-20 09:59:47 +02002773
Kalle Valo5e3dd152013-06-12 20:52:10 +03002774 spin_lock_bh(&ar->data_lock);
2775 ar->rx_channel = conf->chandef.chan;
2776 spin_unlock_bh(&ar->data_lock);
Marek Puzyniake8a50f82013-11-20 09:59:47 +02002777
Michal Kaziord6500972014-04-08 09:56:09 +03002778 ar->radar_enabled = conf->radar_enabled;
2779 ath10k_recalc_radar_detection(ar);
Michal Kaziorc930f742014-01-23 11:38:25 +01002780
2781 if (!cfg80211_chandef_identical(&ar->chandef, &conf->chandef)) {
2782 ar->chandef = conf->chandef;
2783 ath10k_config_chan(ar);
2784 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002785 }
2786
Michal Kazioraffd3212013-07-16 09:54:35 +02002787 if (changed & IEEE80211_CONF_CHANGE_PS)
2788 ath10k_config_ps(ar);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002789
2790 if (changed & IEEE80211_CONF_CHANGE_MONITOR) {
Michal Kazior19337472014-08-28 12:58:16 +02002791 ar->monitor = conf->flags & IEEE80211_CONF_MONITOR;
2792 ret = ath10k_monitor_recalc(ar);
2793 if (ret)
2794 ath10k_warn(ar, "failed to recalc monitor: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002795 }
2796
2797 mutex_unlock(&ar->conf_mutex);
2798 return ret;
2799}
2800
Ben Greear5572a952014-11-24 16:22:10 +02002801static u32 get_nss_from_chainmask(u16 chain_mask)
2802{
2803 if ((chain_mask & 0x15) == 0x15)
2804 return 4;
2805 else if ((chain_mask & 0x7) == 0x7)
2806 return 3;
2807 else if ((chain_mask & 0x3) == 0x3)
2808 return 2;
2809 return 1;
2810}
2811
Kalle Valo5e3dd152013-06-12 20:52:10 +03002812/*
2813 * TODO:
2814 * Figure out how to handle WMI_VDEV_SUBTYPE_P2P_DEVICE,
2815 * because we will send mgmt frames without CCK. This requirement
2816 * for P2P_FIND/GO_NEG should be handled by checking CCK flag
2817 * in the TX packet.
2818 */
2819static int ath10k_add_interface(struct ieee80211_hw *hw,
2820 struct ieee80211_vif *vif)
2821{
2822 struct ath10k *ar = hw->priv;
2823 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
2824 enum wmi_sta_powersave_param param;
2825 int ret = 0;
Kalle Valo5a13e762014-01-20 11:01:46 +02002826 u32 value;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002827 int bit;
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02002828 u32 vdev_param;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002829
2830 mutex_lock(&ar->conf_mutex);
2831
Michal Kazior0dbd09e2013-07-31 10:55:14 +02002832 memset(arvif, 0, sizeof(*arvif));
2833
Kalle Valo5e3dd152013-06-12 20:52:10 +03002834 arvif->ar = ar;
2835 arvif->vif = vif;
2836
Michal Kaziorcc4827b2013-10-16 15:44:45 +03002837 INIT_WORK(&arvif->wep_key_work, ath10k_tx_wep_key_work);
Ben Greeare63b33f2013-10-22 14:54:14 -07002838 INIT_LIST_HEAD(&arvif->list);
Michal Kaziorcc4827b2013-10-16 15:44:45 +03002839
Ben Greeara9aefb32014-08-12 11:02:19 +03002840 if (ar->free_vdev_map == 0) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002841 ath10k_warn(ar, "Free vdev map is empty, no more interfaces allowed.\n");
Kalle Valo5e3dd152013-06-12 20:52:10 +03002842 ret = -EBUSY;
Michal Kazior9dad14a2013-10-16 15:44:45 +03002843 goto err;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002844 }
Ben Greear16c11172014-09-23 14:17:16 -07002845 bit = __ffs64(ar->free_vdev_map);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002846
Ben Greear16c11172014-09-23 14:17:16 -07002847 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac create vdev %i map %llx\n",
2848 bit, ar->free_vdev_map);
2849
2850 arvif->vdev_id = bit;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002851 arvif->vdev_subtype = WMI_VDEV_SUBTYPE_NONE;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002852
2853 if (ar->p2p)
2854 arvif->vdev_subtype = WMI_VDEV_SUBTYPE_P2P_DEVICE;
2855
2856 switch (vif->type) {
2857 case NL80211_IFTYPE_UNSPECIFIED:
2858 case NL80211_IFTYPE_STATION:
2859 arvif->vdev_type = WMI_VDEV_TYPE_STA;
2860 if (vif->p2p)
2861 arvif->vdev_subtype = WMI_VDEV_SUBTYPE_P2P_CLIENT;
2862 break;
2863 case NL80211_IFTYPE_ADHOC:
2864 arvif->vdev_type = WMI_VDEV_TYPE_IBSS;
2865 break;
2866 case NL80211_IFTYPE_AP:
2867 arvif->vdev_type = WMI_VDEV_TYPE_AP;
2868
2869 if (vif->p2p)
2870 arvif->vdev_subtype = WMI_VDEV_SUBTYPE_P2P_GO;
2871 break;
2872 case NL80211_IFTYPE_MONITOR:
2873 arvif->vdev_type = WMI_VDEV_TYPE_MONITOR;
2874 break;
2875 default:
2876 WARN_ON(1);
2877 break;
2878 }
2879
Michal Kazior64badcb2014-09-18 11:18:02 +03002880 /* Some firmware revisions don't wait for beacon tx completion before
2881 * sending another SWBA event. This could lead to hardware using old
2882 * (freed) beacon data in some cases, e.g. tx credit starvation
2883 * combined with missed TBTT. This is very very rare.
2884 *
2885 * On non-IOMMU-enabled hosts this could be a possible security issue
2886 * because hw could beacon some random data on the air. On
2887 * IOMMU-enabled hosts DMAR faults would occur in most cases and target
2888 * device would crash.
2889 *
2890 * Since there are no beacon tx completions (implicit nor explicit)
2891 * propagated to host the only workaround for this is to allocate a
2892 * DMA-coherent buffer for a lifetime of a vif and use it for all
2893 * beacon tx commands. Worst case for this approach is some beacons may
2894 * become corrupted, e.g. have garbled IEs or out-of-date TIM bitmap.
2895 */
2896 if (vif->type == NL80211_IFTYPE_ADHOC ||
2897 vif->type == NL80211_IFTYPE_AP) {
2898 arvif->beacon_buf = dma_zalloc_coherent(ar->dev,
2899 IEEE80211_MAX_FRAME_LEN,
2900 &arvif->beacon_paddr,
Rajkumar Manoharan82d7aba2014-10-10 17:38:27 +05302901 GFP_ATOMIC);
Michal Kazior64badcb2014-09-18 11:18:02 +03002902 if (!arvif->beacon_buf) {
2903 ret = -ENOMEM;
2904 ath10k_warn(ar, "failed to allocate beacon buffer: %d\n",
2905 ret);
2906 goto err;
2907 }
2908 }
2909
2910 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev create %d (add interface) type %d subtype %d bcnmode %s\n",
2911 arvif->vdev_id, arvif->vdev_type, arvif->vdev_subtype,
2912 arvif->beacon_buf ? "single-buf" : "per-skb");
Kalle Valo5e3dd152013-06-12 20:52:10 +03002913
2914 ret = ath10k_wmi_vdev_create(ar, arvif->vdev_id, arvif->vdev_type,
2915 arvif->vdev_subtype, vif->addr);
2916 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002917 ath10k_warn(ar, "failed to create WMI vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02002918 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03002919 goto err;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002920 }
2921
Ben Greear16c11172014-09-23 14:17:16 -07002922 ar->free_vdev_map &= ~(1LL << arvif->vdev_id);
Michal Kazior05791192013-10-16 15:44:45 +03002923 list_add(&arvif->list, &ar->arvifs);
Michal Kazior9dad14a2013-10-16 15:44:45 +03002924
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02002925 vdev_param = ar->wmi.vdev_param->def_keyid;
2926 ret = ath10k_wmi_vdev_set_param(ar, 0, vdev_param,
Michal Kaziorcc4827b2013-10-16 15:44:45 +03002927 arvif->def_wep_key_idx);
Michal Kazior9dad14a2013-10-16 15:44:45 +03002928 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002929 ath10k_warn(ar, "failed to set vdev %i default key id: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02002930 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03002931 goto err_vdev_delete;
2932 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002933
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02002934 vdev_param = ar->wmi.vdev_param->tx_encap_type;
2935 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03002936 ATH10K_HW_TXRX_NATIVE_WIFI);
Bartosz Markowskiebc9abd2013-10-15 09:26:20 +02002937 /* 10.X firmware does not support this VDEV parameter. Do not warn */
Michal Kazior9dad14a2013-10-16 15:44:45 +03002938 if (ret && ret != -EOPNOTSUPP) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002939 ath10k_warn(ar, "failed to set vdev %i TX encapsulation: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02002940 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03002941 goto err_vdev_delete;
2942 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002943
Ben Greear5572a952014-11-24 16:22:10 +02002944 if (ar->cfg_tx_chainmask) {
2945 u16 nss = get_nss_from_chainmask(ar->cfg_tx_chainmask);
2946
2947 vdev_param = ar->wmi.vdev_param->nss;
2948 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
2949 nss);
2950 if (ret) {
2951 ath10k_warn(ar, "failed to set vdev %i chainmask 0x%x, nss %i: %d\n",
2952 arvif->vdev_id, ar->cfg_tx_chainmask, nss,
2953 ret);
2954 goto err_vdev_delete;
2955 }
2956 }
2957
Kalle Valo5e3dd152013-06-12 20:52:10 +03002958 if (arvif->vdev_type == WMI_VDEV_TYPE_AP) {
2959 ret = ath10k_peer_create(ar, arvif->vdev_id, vif->addr);
2960 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002961 ath10k_warn(ar, "failed to create vdev %i peer for AP: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02002962 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03002963 goto err_vdev_delete;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002964 }
Marek Puzyniakcdf07402013-12-30 09:07:51 +01002965
Kalle Valo5a13e762014-01-20 11:01:46 +02002966 ret = ath10k_mac_set_kickout(arvif);
2967 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002968 ath10k_warn(ar, "failed to set vdev %i kickout parameters: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02002969 arvif->vdev_id, ret);
Kalle Valo5a13e762014-01-20 11:01:46 +02002970 goto err_peer_delete;
2971 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002972 }
2973
2974 if (arvif->vdev_type == WMI_VDEV_TYPE_STA) {
2975 param = WMI_STA_PS_PARAM_RX_WAKE_POLICY;
2976 value = WMI_STA_PS_RX_WAKE_POLICY_WAKE;
2977 ret = ath10k_wmi_set_sta_ps_param(ar, arvif->vdev_id,
2978 param, value);
Michal Kazior9dad14a2013-10-16 15:44:45 +03002979 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002980 ath10k_warn(ar, "failed to set vdev %i RX wake policy: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02002981 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03002982 goto err_peer_delete;
2983 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002984
2985 param = WMI_STA_PS_PARAM_TX_WAKE_THRESHOLD;
2986 value = WMI_STA_PS_TX_WAKE_THRESHOLD_ALWAYS;
2987 ret = ath10k_wmi_set_sta_ps_param(ar, arvif->vdev_id,
2988 param, value);
Michal Kazior9dad14a2013-10-16 15:44:45 +03002989 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002990 ath10k_warn(ar, "failed to set vdev %i TX wake thresh: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02002991 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03002992 goto err_peer_delete;
2993 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002994
2995 param = WMI_STA_PS_PARAM_PSPOLL_COUNT;
2996 value = WMI_STA_PS_PSPOLL_COUNT_NO_MAX;
2997 ret = ath10k_wmi_set_sta_ps_param(ar, arvif->vdev_id,
2998 param, value);
Michal Kazior9dad14a2013-10-16 15:44:45 +03002999 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003000 ath10k_warn(ar, "failed to set vdev %i PSPOLL count: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02003001 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03003002 goto err_peer_delete;
3003 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03003004 }
3005
Michal Kazior424121c2013-07-22 14:13:31 +02003006 ret = ath10k_mac_set_rts(arvif, ar->hw->wiphy->rts_threshold);
Michal Kazior9dad14a2013-10-16 15:44:45 +03003007 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003008 ath10k_warn(ar, "failed to set rts threshold for vdev %d: %d\n",
Michal Kazior679c54a2013-07-05 16:15:04 +03003009 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03003010 goto err_peer_delete;
3011 }
Michal Kazior679c54a2013-07-05 16:15:04 +03003012
Michal Kazior424121c2013-07-22 14:13:31 +02003013 ret = ath10k_mac_set_frag(arvif, ar->hw->wiphy->frag_threshold);
Michal Kazior9dad14a2013-10-16 15:44:45 +03003014 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003015 ath10k_warn(ar, "failed to set frag threshold for vdev %d: %d\n",
Michal Kazior679c54a2013-07-05 16:15:04 +03003016 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03003017 goto err_peer_delete;
3018 }
Michal Kazior679c54a2013-07-05 16:15:04 +03003019
Michal Kazior7d9d5582014-10-21 10:40:15 +03003020 arvif->txpower = vif->bss_conf.txpower;
3021 ret = ath10k_mac_txpower_recalc(ar);
3022 if (ret) {
3023 ath10k_warn(ar, "failed to recalc tx power: %d\n", ret);
3024 goto err_peer_delete;
3025 }
3026
Kalle Valo5e3dd152013-06-12 20:52:10 +03003027 mutex_unlock(&ar->conf_mutex);
Michal Kazior9dad14a2013-10-16 15:44:45 +03003028 return 0;
3029
3030err_peer_delete:
3031 if (arvif->vdev_type == WMI_VDEV_TYPE_AP)
3032 ath10k_wmi_peer_delete(ar, arvif->vdev_id, vif->addr);
3033
3034err_vdev_delete:
3035 ath10k_wmi_vdev_delete(ar, arvif->vdev_id);
Ben Greear16c11172014-09-23 14:17:16 -07003036 ar->free_vdev_map |= 1LL << arvif->vdev_id;
Michal Kazior05791192013-10-16 15:44:45 +03003037 list_del(&arvif->list);
Michal Kazior9dad14a2013-10-16 15:44:45 +03003038
3039err:
Michal Kazior64badcb2014-09-18 11:18:02 +03003040 if (arvif->beacon_buf) {
3041 dma_free_coherent(ar->dev, IEEE80211_MAX_FRAME_LEN,
3042 arvif->beacon_buf, arvif->beacon_paddr);
3043 arvif->beacon_buf = NULL;
3044 }
3045
Michal Kazior9dad14a2013-10-16 15:44:45 +03003046 mutex_unlock(&ar->conf_mutex);
3047
Kalle Valo5e3dd152013-06-12 20:52:10 +03003048 return ret;
3049}
3050
3051static void ath10k_remove_interface(struct ieee80211_hw *hw,
3052 struct ieee80211_vif *vif)
3053{
3054 struct ath10k *ar = hw->priv;
3055 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
3056 int ret;
3057
3058 mutex_lock(&ar->conf_mutex);
3059
Michal Kaziorcc4827b2013-10-16 15:44:45 +03003060 cancel_work_sync(&arvif->wep_key_work);
3061
Michal Kaziored543882013-09-13 14:16:56 +02003062 spin_lock_bh(&ar->data_lock);
Michal Kazior64badcb2014-09-18 11:18:02 +03003063 ath10k_mac_vif_beacon_cleanup(arvif);
Michal Kaziored543882013-09-13 14:16:56 +02003064 spin_unlock_bh(&ar->data_lock);
3065
Simon Wunderlich855aed12014-08-02 09:12:54 +03003066 ret = ath10k_spectral_vif_stop(arvif);
3067 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003068 ath10k_warn(ar, "failed to stop spectral for vdev %i: %d\n",
Simon Wunderlich855aed12014-08-02 09:12:54 +03003069 arvif->vdev_id, ret);
3070
Ben Greear16c11172014-09-23 14:17:16 -07003071 ar->free_vdev_map |= 1LL << arvif->vdev_id;
Michal Kazior05791192013-10-16 15:44:45 +03003072 list_del(&arvif->list);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003073
3074 if (arvif->vdev_type == WMI_VDEV_TYPE_AP) {
3075 ret = ath10k_peer_delete(arvif->ar, arvif->vdev_id, vif->addr);
3076 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003077 ath10k_warn(ar, "failed to remove peer for AP vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02003078 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003079
3080 kfree(arvif->u.ap.noa_data);
3081 }
3082
Michal Kazior7aa7a722014-08-25 12:09:38 +02003083 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %i delete (remove interface)\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03003084 arvif->vdev_id);
3085
Kalle Valo5e3dd152013-06-12 20:52:10 +03003086 ret = ath10k_wmi_vdev_delete(ar, arvif->vdev_id);
3087 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003088 ath10k_warn(ar, "failed to delete WMI vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02003089 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003090
Kalle Valo5e3dd152013-06-12 20:52:10 +03003091 ath10k_peer_cleanup(ar, arvif->vdev_id);
3092
3093 mutex_unlock(&ar->conf_mutex);
3094}
3095
3096/*
3097 * FIXME: Has to be verified.
3098 */
3099#define SUPPORTED_FILTERS \
3100 (FIF_PROMISC_IN_BSS | \
3101 FIF_ALLMULTI | \
3102 FIF_CONTROL | \
3103 FIF_PSPOLL | \
3104 FIF_OTHER_BSS | \
3105 FIF_BCN_PRBRESP_PROMISC | \
3106 FIF_PROBE_REQ | \
3107 FIF_FCSFAIL)
3108
3109static void ath10k_configure_filter(struct ieee80211_hw *hw,
3110 unsigned int changed_flags,
3111 unsigned int *total_flags,
3112 u64 multicast)
3113{
3114 struct ath10k *ar = hw->priv;
3115 int ret;
3116
3117 mutex_lock(&ar->conf_mutex);
3118
3119 changed_flags &= SUPPORTED_FILTERS;
3120 *total_flags &= SUPPORTED_FILTERS;
3121 ar->filter_flags = *total_flags;
3122
Michal Kazior19337472014-08-28 12:58:16 +02003123 ret = ath10k_monitor_recalc(ar);
3124 if (ret)
3125 ath10k_warn(ar, "failed to recalc montior: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003126
3127 mutex_unlock(&ar->conf_mutex);
3128}
3129
3130static void ath10k_bss_info_changed(struct ieee80211_hw *hw,
3131 struct ieee80211_vif *vif,
3132 struct ieee80211_bss_conf *info,
3133 u32 changed)
3134{
3135 struct ath10k *ar = hw->priv;
3136 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
3137 int ret = 0;
Kalle Valoaf762c02014-09-14 12:50:17 +03003138 u32 vdev_param, pdev_param, slottime, preamble;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003139
3140 mutex_lock(&ar->conf_mutex);
3141
3142 if (changed & BSS_CHANGED_IBSS)
3143 ath10k_control_ibss(arvif, info, vif->addr);
3144
3145 if (changed & BSS_CHANGED_BEACON_INT) {
3146 arvif->beacon_interval = info->beacon_int;
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02003147 vdev_param = ar->wmi.vdev_param->beacon_interval;
3148 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03003149 arvif->beacon_interval);
Michal Kazior7aa7a722014-08-25 12:09:38 +02003150 ath10k_dbg(ar, ATH10K_DBG_MAC,
Kalle Valo60c3daa2013-09-08 17:56:07 +03003151 "mac vdev %d beacon_interval %d\n",
3152 arvif->vdev_id, arvif->beacon_interval);
3153
Kalle Valo5e3dd152013-06-12 20:52:10 +03003154 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003155 ath10k_warn(ar, "failed to set beacon interval for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02003156 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003157 }
3158
3159 if (changed & BSS_CHANGED_BEACON) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003160 ath10k_dbg(ar, ATH10K_DBG_MAC,
Kalle Valo60c3daa2013-09-08 17:56:07 +03003161 "vdev %d set beacon tx mode to staggered\n",
3162 arvif->vdev_id);
3163
Bartosz Markowski226a3392013-09-26 17:47:16 +02003164 pdev_param = ar->wmi.pdev_param->beacon_tx_mode;
3165 ret = ath10k_wmi_pdev_set_param(ar, pdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03003166 WMI_BEACON_STAGGERED_MODE);
3167 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003168 ath10k_warn(ar, "failed to set beacon mode for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02003169 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003170 }
3171
John W. Linvilleb70727e2013-06-13 13:34:29 -04003172 if (changed & BSS_CHANGED_BEACON_INFO) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03003173 arvif->dtim_period = info->dtim_period;
3174
Michal Kazior7aa7a722014-08-25 12:09:38 +02003175 ath10k_dbg(ar, ATH10K_DBG_MAC,
Kalle Valo60c3daa2013-09-08 17:56:07 +03003176 "mac vdev %d dtim_period %d\n",
3177 arvif->vdev_id, arvif->dtim_period);
3178
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02003179 vdev_param = ar->wmi.vdev_param->dtim_period;
3180 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03003181 arvif->dtim_period);
3182 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003183 ath10k_warn(ar, "failed to set dtim period for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02003184 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003185 }
3186
3187 if (changed & BSS_CHANGED_SSID &&
3188 vif->type == NL80211_IFTYPE_AP) {
3189 arvif->u.ap.ssid_len = info->ssid_len;
3190 if (info->ssid_len)
3191 memcpy(arvif->u.ap.ssid, info->ssid, info->ssid_len);
3192 arvif->u.ap.hidden_ssid = info->hidden_ssid;
3193 }
3194
Michal Kazior077efc82014-10-21 10:10:29 +03003195 if (changed & BSS_CHANGED_BSSID && !is_zero_ether_addr(info->bssid))
3196 ether_addr_copy(arvif->bssid, info->bssid);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003197
3198 if (changed & BSS_CHANGED_BEACON_ENABLED)
3199 ath10k_control_beaconing(arvif, info);
3200
3201 if (changed & BSS_CHANGED_ERP_CTS_PROT) {
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02003202 arvif->use_cts_prot = info->use_cts_prot;
Michal Kazior7aa7a722014-08-25 12:09:38 +02003203 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %d cts_prot %d\n",
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02003204 arvif->vdev_id, info->use_cts_prot);
Kalle Valo60c3daa2013-09-08 17:56:07 +03003205
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02003206 ret = ath10k_recalc_rtscts_prot(arvif);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003207 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003208 ath10k_warn(ar, "failed to recalculate rts/cts prot for vdev %d: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02003209 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003210 }
3211
3212 if (changed & BSS_CHANGED_ERP_SLOT) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03003213 if (info->use_short_slot)
3214 slottime = WMI_VDEV_SLOT_TIME_SHORT; /* 9us */
3215
3216 else
3217 slottime = WMI_VDEV_SLOT_TIME_LONG; /* 20us */
3218
Michal Kazior7aa7a722014-08-25 12:09:38 +02003219 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %d slot_time %d\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03003220 arvif->vdev_id, slottime);
3221
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02003222 vdev_param = ar->wmi.vdev_param->slot_time;
3223 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03003224 slottime);
3225 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003226 ath10k_warn(ar, "failed to set erp slot for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02003227 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003228 }
3229
3230 if (changed & BSS_CHANGED_ERP_PREAMBLE) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03003231 if (info->use_short_preamble)
3232 preamble = WMI_VDEV_PREAMBLE_SHORT;
3233 else
3234 preamble = WMI_VDEV_PREAMBLE_LONG;
3235
Michal Kazior7aa7a722014-08-25 12:09:38 +02003236 ath10k_dbg(ar, ATH10K_DBG_MAC,
Kalle Valo60c3daa2013-09-08 17:56:07 +03003237 "mac vdev %d preamble %dn",
3238 arvif->vdev_id, preamble);
3239
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02003240 vdev_param = ar->wmi.vdev_param->preamble;
3241 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03003242 preamble);
3243 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003244 ath10k_warn(ar, "failed to set preamble for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02003245 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003246 }
3247
3248 if (changed & BSS_CHANGED_ASSOC) {
Michal Kaziore556f112014-08-28 12:58:17 +02003249 if (info->assoc) {
3250 /* Workaround: Make sure monitor vdev is not running
3251 * when associating to prevent some firmware revisions
3252 * (e.g. 10.1 and 10.2) from crashing.
3253 */
3254 if (ar->monitor_started)
3255 ath10k_monitor_stop(ar);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003256 ath10k_bss_assoc(hw, vif, info);
Michal Kaziore556f112014-08-28 12:58:17 +02003257 ath10k_monitor_recalc(ar);
Michal Kazior077efc82014-10-21 10:10:29 +03003258 } else {
3259 ath10k_bss_disassoc(hw, vif);
Michal Kaziore556f112014-08-28 12:58:17 +02003260 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03003261 }
3262
Michal Kazior7d9d5582014-10-21 10:40:15 +03003263 if (changed & BSS_CHANGED_TXPOWER) {
3264 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev_id %i txpower %d\n",
3265 arvif->vdev_id, info->txpower);
3266
3267 arvif->txpower = info->txpower;
3268 ret = ath10k_mac_txpower_recalc(ar);
3269 if (ret)
3270 ath10k_warn(ar, "failed to recalc tx power: %d\n", ret);
3271 }
3272
Kalle Valo5e3dd152013-06-12 20:52:10 +03003273 mutex_unlock(&ar->conf_mutex);
3274}
3275
3276static int ath10k_hw_scan(struct ieee80211_hw *hw,
3277 struct ieee80211_vif *vif,
David Spinadelc56ef672014-02-05 15:21:13 +02003278 struct ieee80211_scan_request *hw_req)
Kalle Valo5e3dd152013-06-12 20:52:10 +03003279{
3280 struct ath10k *ar = hw->priv;
3281 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
David Spinadelc56ef672014-02-05 15:21:13 +02003282 struct cfg80211_scan_request *req = &hw_req->req;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003283 struct wmi_start_scan_arg arg;
3284 int ret = 0;
3285 int i;
3286
3287 mutex_lock(&ar->conf_mutex);
3288
3289 spin_lock_bh(&ar->data_lock);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003290 switch (ar->scan.state) {
3291 case ATH10K_SCAN_IDLE:
3292 reinit_completion(&ar->scan.started);
3293 reinit_completion(&ar->scan.completed);
3294 ar->scan.state = ATH10K_SCAN_STARTING;
3295 ar->scan.is_roc = false;
3296 ar->scan.vdev_id = arvif->vdev_id;
3297 ret = 0;
3298 break;
3299 case ATH10K_SCAN_STARTING:
3300 case ATH10K_SCAN_RUNNING:
3301 case ATH10K_SCAN_ABORTING:
Kalle Valo5e3dd152013-06-12 20:52:10 +03003302 ret = -EBUSY;
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003303 break;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003304 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03003305 spin_unlock_bh(&ar->data_lock);
3306
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003307 if (ret)
3308 goto exit;
3309
Kalle Valo5e3dd152013-06-12 20:52:10 +03003310 memset(&arg, 0, sizeof(arg));
3311 ath10k_wmi_start_scan_init(ar, &arg);
3312 arg.vdev_id = arvif->vdev_id;
3313 arg.scan_id = ATH10K_SCAN_ID;
3314
3315 if (!req->no_cck)
3316 arg.scan_ctrl_flags |= WMI_SCAN_ADD_CCK_RATES;
3317
3318 if (req->ie_len) {
3319 arg.ie_len = req->ie_len;
3320 memcpy(arg.ie, req->ie, arg.ie_len);
3321 }
3322
3323 if (req->n_ssids) {
3324 arg.n_ssids = req->n_ssids;
3325 for (i = 0; i < arg.n_ssids; i++) {
3326 arg.ssids[i].len = req->ssids[i].ssid_len;
3327 arg.ssids[i].ssid = req->ssids[i].ssid;
3328 }
Michal Kaziordcd4a562013-07-31 10:55:12 +02003329 } else {
3330 arg.scan_ctrl_flags |= WMI_SCAN_FLAG_PASSIVE;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003331 }
3332
3333 if (req->n_channels) {
3334 arg.n_channels = req->n_channels;
3335 for (i = 0; i < arg.n_channels; i++)
3336 arg.channels[i] = req->channels[i]->center_freq;
3337 }
3338
3339 ret = ath10k_start_scan(ar, &arg);
3340 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003341 ath10k_warn(ar, "failed to start hw scan: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003342 spin_lock_bh(&ar->data_lock);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003343 ar->scan.state = ATH10K_SCAN_IDLE;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003344 spin_unlock_bh(&ar->data_lock);
3345 }
3346
3347exit:
3348 mutex_unlock(&ar->conf_mutex);
3349 return ret;
3350}
3351
3352static void ath10k_cancel_hw_scan(struct ieee80211_hw *hw,
3353 struct ieee80211_vif *vif)
3354{
3355 struct ath10k *ar = hw->priv;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003356
3357 mutex_lock(&ar->conf_mutex);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003358 ath10k_scan_abort(ar);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003359 mutex_unlock(&ar->conf_mutex);
Michal Kazior4eb2e162014-10-28 10:23:09 +01003360
3361 cancel_delayed_work_sync(&ar->scan.timeout);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003362}
3363
Michal Kaziorcfb27d22013-12-02 09:06:36 +01003364static void ath10k_set_key_h_def_keyidx(struct ath10k *ar,
3365 struct ath10k_vif *arvif,
3366 enum set_key_cmd cmd,
3367 struct ieee80211_key_conf *key)
3368{
3369 u32 vdev_param = arvif->ar->wmi.vdev_param->def_keyid;
3370 int ret;
3371
3372 /* 10.1 firmware branch requires default key index to be set to group
3373 * key index after installing it. Otherwise FW/HW Txes corrupted
3374 * frames with multi-vif APs. This is not required for main firmware
3375 * branch (e.g. 636).
3376 *
3377 * FIXME: This has been tested only in AP. It remains unknown if this
3378 * is required for multi-vif STA interfaces on 10.1 */
3379
3380 if (arvif->vdev_type != WMI_VDEV_TYPE_AP)
3381 return;
3382
3383 if (key->cipher == WLAN_CIPHER_SUITE_WEP40)
3384 return;
3385
3386 if (key->cipher == WLAN_CIPHER_SUITE_WEP104)
3387 return;
3388
3389 if (key->flags & IEEE80211_KEY_FLAG_PAIRWISE)
3390 return;
3391
3392 if (cmd != SET_KEY)
3393 return;
3394
3395 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
3396 key->keyidx);
3397 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003398 ath10k_warn(ar, "failed to set vdev %i group key as default key: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02003399 arvif->vdev_id, ret);
Michal Kaziorcfb27d22013-12-02 09:06:36 +01003400}
3401
Kalle Valo5e3dd152013-06-12 20:52:10 +03003402static int ath10k_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd,
3403 struct ieee80211_vif *vif, struct ieee80211_sta *sta,
3404 struct ieee80211_key_conf *key)
3405{
3406 struct ath10k *ar = hw->priv;
3407 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
3408 struct ath10k_peer *peer;
3409 const u8 *peer_addr;
3410 bool is_wep = key->cipher == WLAN_CIPHER_SUITE_WEP40 ||
3411 key->cipher == WLAN_CIPHER_SUITE_WEP104;
3412 int ret = 0;
3413
3414 if (key->keyidx > WMI_MAX_KEY_INDEX)
3415 return -ENOSPC;
3416
3417 mutex_lock(&ar->conf_mutex);
3418
3419 if (sta)
3420 peer_addr = sta->addr;
3421 else if (arvif->vdev_type == WMI_VDEV_TYPE_STA)
3422 peer_addr = vif->bss_conf.bssid;
3423 else
3424 peer_addr = vif->addr;
3425
3426 key->hw_key_idx = key->keyidx;
3427
3428 /* the peer should not disappear in mid-way (unless FW goes awry) since
3429 * we already hold conf_mutex. we just make sure its there now. */
3430 spin_lock_bh(&ar->data_lock);
3431 peer = ath10k_peer_find(ar, arvif->vdev_id, peer_addr);
3432 spin_unlock_bh(&ar->data_lock);
3433
3434 if (!peer) {
3435 if (cmd == SET_KEY) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003436 ath10k_warn(ar, "failed to install key for non-existent peer %pM\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03003437 peer_addr);
3438 ret = -EOPNOTSUPP;
3439 goto exit;
3440 } else {
3441 /* if the peer doesn't exist there is no key to disable
3442 * anymore */
3443 goto exit;
3444 }
3445 }
3446
3447 if (is_wep) {
3448 if (cmd == SET_KEY)
3449 arvif->wep_keys[key->keyidx] = key;
3450 else
3451 arvif->wep_keys[key->keyidx] = NULL;
3452
3453 if (cmd == DISABLE_KEY)
3454 ath10k_clear_vdev_key(arvif, key);
3455 }
3456
3457 ret = ath10k_install_key(arvif, key, cmd, peer_addr);
3458 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003459 ath10k_warn(ar, "failed to install key for vdev %i peer %pM: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02003460 arvif->vdev_id, peer_addr, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003461 goto exit;
3462 }
3463
Michal Kaziorcfb27d22013-12-02 09:06:36 +01003464 ath10k_set_key_h_def_keyidx(ar, arvif, cmd, key);
3465
Kalle Valo5e3dd152013-06-12 20:52:10 +03003466 spin_lock_bh(&ar->data_lock);
3467 peer = ath10k_peer_find(ar, arvif->vdev_id, peer_addr);
3468 if (peer && cmd == SET_KEY)
3469 peer->keys[key->keyidx] = key;
3470 else if (peer && cmd == DISABLE_KEY)
3471 peer->keys[key->keyidx] = NULL;
3472 else if (peer == NULL)
3473 /* impossible unless FW goes crazy */
Michal Kazior7aa7a722014-08-25 12:09:38 +02003474 ath10k_warn(ar, "Peer %pM disappeared!\n", peer_addr);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003475 spin_unlock_bh(&ar->data_lock);
3476
3477exit:
3478 mutex_unlock(&ar->conf_mutex);
3479 return ret;
3480}
3481
Michal Kazior9797feb2014-02-14 14:49:48 +01003482static void ath10k_sta_rc_update_wk(struct work_struct *wk)
3483{
3484 struct ath10k *ar;
3485 struct ath10k_vif *arvif;
3486 struct ath10k_sta *arsta;
3487 struct ieee80211_sta *sta;
3488 u32 changed, bw, nss, smps;
3489 int err;
3490
3491 arsta = container_of(wk, struct ath10k_sta, update_wk);
3492 sta = container_of((void *)arsta, struct ieee80211_sta, drv_priv);
3493 arvif = arsta->arvif;
3494 ar = arvif->ar;
3495
3496 spin_lock_bh(&ar->data_lock);
3497
3498 changed = arsta->changed;
3499 arsta->changed = 0;
3500
3501 bw = arsta->bw;
3502 nss = arsta->nss;
3503 smps = arsta->smps;
3504
3505 spin_unlock_bh(&ar->data_lock);
3506
3507 mutex_lock(&ar->conf_mutex);
3508
3509 if (changed & IEEE80211_RC_BW_CHANGED) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003510 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac update sta %pM peer bw %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01003511 sta->addr, bw);
3512
3513 err = ath10k_wmi_peer_set_param(ar, arvif->vdev_id, sta->addr,
3514 WMI_PEER_CHAN_WIDTH, bw);
3515 if (err)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003516 ath10k_warn(ar, "failed to update STA %pM peer bw %d: %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01003517 sta->addr, bw, err);
3518 }
3519
3520 if (changed & IEEE80211_RC_NSS_CHANGED) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003521 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac update sta %pM nss %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01003522 sta->addr, nss);
3523
3524 err = ath10k_wmi_peer_set_param(ar, arvif->vdev_id, sta->addr,
3525 WMI_PEER_NSS, nss);
3526 if (err)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003527 ath10k_warn(ar, "failed to update STA %pM nss %d: %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01003528 sta->addr, nss, err);
3529 }
3530
3531 if (changed & IEEE80211_RC_SMPS_CHANGED) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003532 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac update sta %pM smps %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01003533 sta->addr, smps);
3534
3535 err = ath10k_wmi_peer_set_param(ar, arvif->vdev_id, sta->addr,
3536 WMI_PEER_SMPS_STATE, smps);
3537 if (err)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003538 ath10k_warn(ar, "failed to update STA %pM smps %d: %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01003539 sta->addr, smps, err);
3540 }
3541
Chun-Yeow Yeoh44d6fa92014-03-07 10:19:30 +02003542 if (changed & IEEE80211_RC_SUPP_RATES_CHANGED) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003543 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac update sta %pM supp rates\n",
Chun-Yeow Yeoh44d6fa92014-03-07 10:19:30 +02003544 sta->addr);
3545
Michal Kazior590922a2014-10-21 10:10:29 +03003546 err = ath10k_station_assoc(ar, arvif->vif, sta, true);
Chun-Yeow Yeoh44d6fa92014-03-07 10:19:30 +02003547 if (err)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003548 ath10k_warn(ar, "failed to reassociate station: %pM\n",
Chun-Yeow Yeoh44d6fa92014-03-07 10:19:30 +02003549 sta->addr);
3550 }
3551
Michal Kazior9797feb2014-02-14 14:49:48 +01003552 mutex_unlock(&ar->conf_mutex);
3553}
3554
Kalle Valo5e3dd152013-06-12 20:52:10 +03003555static int ath10k_sta_state(struct ieee80211_hw *hw,
3556 struct ieee80211_vif *vif,
3557 struct ieee80211_sta *sta,
3558 enum ieee80211_sta_state old_state,
3559 enum ieee80211_sta_state new_state)
3560{
3561 struct ath10k *ar = hw->priv;
3562 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kazior9797feb2014-02-14 14:49:48 +01003563 struct ath10k_sta *arsta = (struct ath10k_sta *)sta->drv_priv;
Bartosz Markowski0e759f32014-01-02 14:38:33 +01003564 int max_num_peers;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003565 int ret = 0;
3566
Michal Kazior76f90022014-02-25 09:29:57 +02003567 if (old_state == IEEE80211_STA_NOTEXIST &&
3568 new_state == IEEE80211_STA_NONE) {
3569 memset(arsta, 0, sizeof(*arsta));
3570 arsta->arvif = arvif;
3571 INIT_WORK(&arsta->update_wk, ath10k_sta_rc_update_wk);
3572 }
3573
Michal Kazior9797feb2014-02-14 14:49:48 +01003574 /* cancel must be done outside the mutex to avoid deadlock */
3575 if ((old_state == IEEE80211_STA_NONE &&
3576 new_state == IEEE80211_STA_NOTEXIST))
3577 cancel_work_sync(&arsta->update_wk);
3578
Kalle Valo5e3dd152013-06-12 20:52:10 +03003579 mutex_lock(&ar->conf_mutex);
3580
3581 if (old_state == IEEE80211_STA_NOTEXIST &&
Michal Kazior077efc82014-10-21 10:10:29 +03003582 new_state == IEEE80211_STA_NONE) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03003583 /*
3584 * New station addition.
3585 */
Bartosz Markowski0e759f32014-01-02 14:38:33 +01003586 if (test_bit(ATH10K_FW_FEATURE_WMI_10X, ar->fw_features))
3587 max_num_peers = TARGET_10X_NUM_PEERS_MAX - 1;
3588 else
3589 max_num_peers = TARGET_NUM_PEERS;
3590
3591 if (ar->num_peers >= max_num_peers) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003592 ath10k_warn(ar, "number of peers exceeded: peers number %d (max peers %d)\n",
Bartosz Markowski0e759f32014-01-02 14:38:33 +01003593 ar->num_peers, max_num_peers);
3594 ret = -ENOBUFS;
3595 goto exit;
3596 }
3597
Michal Kazior7aa7a722014-08-25 12:09:38 +02003598 ath10k_dbg(ar, ATH10K_DBG_MAC,
Bartosz Markowski0e759f32014-01-02 14:38:33 +01003599 "mac vdev %d peer create %pM (new sta) num_peers %d\n",
3600 arvif->vdev_id, sta->addr, ar->num_peers);
Kalle Valo60c3daa2013-09-08 17:56:07 +03003601
Kalle Valo5e3dd152013-06-12 20:52:10 +03003602 ret = ath10k_peer_create(ar, arvif->vdev_id, sta->addr);
3603 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003604 ath10k_warn(ar, "failed to add peer %pM for vdev %d when adding a new sta: %i\n",
Ben Greear479398b2013-11-04 09:19:34 -08003605 sta->addr, arvif->vdev_id, ret);
Michal Kazior077efc82014-10-21 10:10:29 +03003606
3607 if (vif->type == NL80211_IFTYPE_STATION) {
3608 WARN_ON(arvif->is_started);
3609
3610 ret = ath10k_vdev_start(arvif);
3611 if (ret) {
3612 ath10k_warn(ar, "failed to start vdev %i: %d\n",
3613 arvif->vdev_id, ret);
3614 WARN_ON(ath10k_peer_delete(ar, arvif->vdev_id,
3615 sta->addr));
3616 goto exit;
3617 }
3618
3619 arvif->is_started = true;
3620 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03003621 } else if ((old_state == IEEE80211_STA_NONE &&
3622 new_state == IEEE80211_STA_NOTEXIST)) {
3623 /*
3624 * Existing station deletion.
3625 */
Michal Kazior7aa7a722014-08-25 12:09:38 +02003626 ath10k_dbg(ar, ATH10K_DBG_MAC,
Kalle Valo60c3daa2013-09-08 17:56:07 +03003627 "mac vdev %d peer delete %pM (sta gone)\n",
3628 arvif->vdev_id, sta->addr);
Michal Kazior077efc82014-10-21 10:10:29 +03003629
3630 if (vif->type == NL80211_IFTYPE_STATION) {
3631 WARN_ON(!arvif->is_started);
3632
3633 ret = ath10k_vdev_stop(arvif);
3634 if (ret)
3635 ath10k_warn(ar, "failed to stop vdev %i: %d\n",
3636 arvif->vdev_id, ret);
3637
3638 arvif->is_started = false;
3639 }
3640
Kalle Valo5e3dd152013-06-12 20:52:10 +03003641 ret = ath10k_peer_delete(ar, arvif->vdev_id, sta->addr);
3642 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003643 ath10k_warn(ar, "failed to delete peer %pM for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02003644 sta->addr, arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003645
Kalle Valo5e3dd152013-06-12 20:52:10 +03003646 } else if (old_state == IEEE80211_STA_AUTH &&
3647 new_state == IEEE80211_STA_ASSOC &&
3648 (vif->type == NL80211_IFTYPE_AP ||
3649 vif->type == NL80211_IFTYPE_ADHOC)) {
3650 /*
3651 * New association.
3652 */
Michal Kazior7aa7a722014-08-25 12:09:38 +02003653 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac sta %pM associated\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03003654 sta->addr);
3655
Michal Kazior590922a2014-10-21 10:10:29 +03003656 ret = ath10k_station_assoc(ar, vif, sta, false);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003657 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003658 ath10k_warn(ar, "failed to associate station %pM for vdev %i: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02003659 sta->addr, arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003660 } else if (old_state == IEEE80211_STA_ASSOC &&
3661 new_state == IEEE80211_STA_AUTH &&
3662 (vif->type == NL80211_IFTYPE_AP ||
3663 vif->type == NL80211_IFTYPE_ADHOC)) {
3664 /*
3665 * Disassociation.
3666 */
Michal Kazior7aa7a722014-08-25 12:09:38 +02003667 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac sta %pM disassociated\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03003668 sta->addr);
3669
Michal Kazior590922a2014-10-21 10:10:29 +03003670 ret = ath10k_station_disassoc(ar, vif, sta);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003671 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003672 ath10k_warn(ar, "failed to disassociate station: %pM vdev %i: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02003673 sta->addr, arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003674 }
Bartosz Markowski0e759f32014-01-02 14:38:33 +01003675exit:
Kalle Valo5e3dd152013-06-12 20:52:10 +03003676 mutex_unlock(&ar->conf_mutex);
3677 return ret;
3678}
3679
3680static int ath10k_conf_tx_uapsd(struct ath10k *ar, struct ieee80211_vif *vif,
Kalle Valo5b07e072014-09-14 12:50:06 +03003681 u16 ac, bool enable)
Kalle Valo5e3dd152013-06-12 20:52:10 +03003682{
3683 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
3684 u32 value = 0;
3685 int ret = 0;
3686
Michal Kazior548db542013-07-05 16:15:15 +03003687 lockdep_assert_held(&ar->conf_mutex);
3688
Kalle Valo5e3dd152013-06-12 20:52:10 +03003689 if (arvif->vdev_type != WMI_VDEV_TYPE_STA)
3690 return 0;
3691
3692 switch (ac) {
3693 case IEEE80211_AC_VO:
3694 value = WMI_STA_PS_UAPSD_AC3_DELIVERY_EN |
3695 WMI_STA_PS_UAPSD_AC3_TRIGGER_EN;
3696 break;
3697 case IEEE80211_AC_VI:
3698 value = WMI_STA_PS_UAPSD_AC2_DELIVERY_EN |
3699 WMI_STA_PS_UAPSD_AC2_TRIGGER_EN;
3700 break;
3701 case IEEE80211_AC_BE:
3702 value = WMI_STA_PS_UAPSD_AC1_DELIVERY_EN |
3703 WMI_STA_PS_UAPSD_AC1_TRIGGER_EN;
3704 break;
3705 case IEEE80211_AC_BK:
3706 value = WMI_STA_PS_UAPSD_AC0_DELIVERY_EN |
3707 WMI_STA_PS_UAPSD_AC0_TRIGGER_EN;
3708 break;
3709 }
3710
3711 if (enable)
3712 arvif->u.sta.uapsd |= value;
3713 else
3714 arvif->u.sta.uapsd &= ~value;
3715
3716 ret = ath10k_wmi_set_sta_ps_param(ar, arvif->vdev_id,
3717 WMI_STA_PS_PARAM_UAPSD,
3718 arvif->u.sta.uapsd);
3719 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003720 ath10k_warn(ar, "failed to set uapsd params: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003721 goto exit;
3722 }
3723
3724 if (arvif->u.sta.uapsd)
3725 value = WMI_STA_PS_RX_WAKE_POLICY_POLL_UAPSD;
3726 else
3727 value = WMI_STA_PS_RX_WAKE_POLICY_WAKE;
3728
3729 ret = ath10k_wmi_set_sta_ps_param(ar, arvif->vdev_id,
3730 WMI_STA_PS_PARAM_RX_WAKE_POLICY,
3731 value);
3732 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003733 ath10k_warn(ar, "failed to set rx wake param: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003734
3735exit:
3736 return ret;
3737}
3738
3739static int ath10k_conf_tx(struct ieee80211_hw *hw,
3740 struct ieee80211_vif *vif, u16 ac,
3741 const struct ieee80211_tx_queue_params *params)
3742{
3743 struct ath10k *ar = hw->priv;
3744 struct wmi_wmm_params_arg *p = NULL;
3745 int ret;
3746
3747 mutex_lock(&ar->conf_mutex);
3748
3749 switch (ac) {
3750 case IEEE80211_AC_VO:
3751 p = &ar->wmm_params.ac_vo;
3752 break;
3753 case IEEE80211_AC_VI:
3754 p = &ar->wmm_params.ac_vi;
3755 break;
3756 case IEEE80211_AC_BE:
3757 p = &ar->wmm_params.ac_be;
3758 break;
3759 case IEEE80211_AC_BK:
3760 p = &ar->wmm_params.ac_bk;
3761 break;
3762 }
3763
3764 if (WARN_ON(!p)) {
3765 ret = -EINVAL;
3766 goto exit;
3767 }
3768
3769 p->cwmin = params->cw_min;
3770 p->cwmax = params->cw_max;
3771 p->aifs = params->aifs;
3772
3773 /*
3774 * The channel time duration programmed in the HW is in absolute
3775 * microseconds, while mac80211 gives the txop in units of
3776 * 32 microseconds.
3777 */
3778 p->txop = params->txop * 32;
3779
3780 /* FIXME: FW accepts wmm params per hw, not per vif */
3781 ret = ath10k_wmi_pdev_set_wmm_params(ar, &ar->wmm_params);
3782 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003783 ath10k_warn(ar, "failed to set wmm params: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003784 goto exit;
3785 }
3786
3787 ret = ath10k_conf_tx_uapsd(ar, vif, ac, params->uapsd);
3788 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003789 ath10k_warn(ar, "failed to set sta uapsd: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003790
3791exit:
3792 mutex_unlock(&ar->conf_mutex);
3793 return ret;
3794}
3795
3796#define ATH10K_ROC_TIMEOUT_HZ (2*HZ)
3797
3798static int ath10k_remain_on_channel(struct ieee80211_hw *hw,
3799 struct ieee80211_vif *vif,
3800 struct ieee80211_channel *chan,
3801 int duration,
3802 enum ieee80211_roc_type type)
3803{
3804 struct ath10k *ar = hw->priv;
3805 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
3806 struct wmi_start_scan_arg arg;
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003807 int ret = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003808
3809 mutex_lock(&ar->conf_mutex);
3810
3811 spin_lock_bh(&ar->data_lock);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003812 switch (ar->scan.state) {
3813 case ATH10K_SCAN_IDLE:
3814 reinit_completion(&ar->scan.started);
3815 reinit_completion(&ar->scan.completed);
3816 reinit_completion(&ar->scan.on_channel);
3817 ar->scan.state = ATH10K_SCAN_STARTING;
3818 ar->scan.is_roc = true;
3819 ar->scan.vdev_id = arvif->vdev_id;
3820 ar->scan.roc_freq = chan->center_freq;
3821 ret = 0;
3822 break;
3823 case ATH10K_SCAN_STARTING:
3824 case ATH10K_SCAN_RUNNING:
3825 case ATH10K_SCAN_ABORTING:
Kalle Valo5e3dd152013-06-12 20:52:10 +03003826 ret = -EBUSY;
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003827 break;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003828 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03003829 spin_unlock_bh(&ar->data_lock);
3830
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003831 if (ret)
3832 goto exit;
3833
Kalle Valo5e3dd152013-06-12 20:52:10 +03003834 memset(&arg, 0, sizeof(arg));
3835 ath10k_wmi_start_scan_init(ar, &arg);
3836 arg.vdev_id = arvif->vdev_id;
3837 arg.scan_id = ATH10K_SCAN_ID;
3838 arg.n_channels = 1;
3839 arg.channels[0] = chan->center_freq;
3840 arg.dwell_time_active = duration;
3841 arg.dwell_time_passive = duration;
3842 arg.max_scan_time = 2 * duration;
3843 arg.scan_ctrl_flags |= WMI_SCAN_FLAG_PASSIVE;
3844 arg.scan_ctrl_flags |= WMI_SCAN_FILTER_PROBE_REQ;
3845
3846 ret = ath10k_start_scan(ar, &arg);
3847 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003848 ath10k_warn(ar, "failed to start roc scan: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003849 spin_lock_bh(&ar->data_lock);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003850 ar->scan.state = ATH10K_SCAN_IDLE;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003851 spin_unlock_bh(&ar->data_lock);
3852 goto exit;
3853 }
3854
3855 ret = wait_for_completion_timeout(&ar->scan.on_channel, 3*HZ);
3856 if (ret == 0) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003857 ath10k_warn(ar, "failed to switch to channel for roc scan\n");
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003858
3859 ret = ath10k_scan_stop(ar);
3860 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003861 ath10k_warn(ar, "failed to stop scan: %d\n", ret);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003862
Kalle Valo5e3dd152013-06-12 20:52:10 +03003863 ret = -ETIMEDOUT;
3864 goto exit;
3865 }
3866
3867 ret = 0;
3868exit:
3869 mutex_unlock(&ar->conf_mutex);
3870 return ret;
3871}
3872
3873static int ath10k_cancel_remain_on_channel(struct ieee80211_hw *hw)
3874{
3875 struct ath10k *ar = hw->priv;
3876
3877 mutex_lock(&ar->conf_mutex);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003878 ath10k_scan_abort(ar);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003879 mutex_unlock(&ar->conf_mutex);
3880
Michal Kazior4eb2e162014-10-28 10:23:09 +01003881 cancel_delayed_work_sync(&ar->scan.timeout);
3882
Kalle Valo5e3dd152013-06-12 20:52:10 +03003883 return 0;
3884}
3885
3886/*
3887 * Both RTS and Fragmentation threshold are interface-specific
3888 * in ath10k, but device-specific in mac80211.
3889 */
Kalle Valo5e3dd152013-06-12 20:52:10 +03003890
3891static int ath10k_set_rts_threshold(struct ieee80211_hw *hw, u32 value)
3892{
Kalle Valo5e3dd152013-06-12 20:52:10 +03003893 struct ath10k *ar = hw->priv;
Michal Kaziorad088bf2013-10-16 15:44:46 +03003894 struct ath10k_vif *arvif;
3895 int ret = 0;
Michal Kazior548db542013-07-05 16:15:15 +03003896
Michal Kaziorad088bf2013-10-16 15:44:46 +03003897 mutex_lock(&ar->conf_mutex);
3898 list_for_each_entry(arvif, &ar->arvifs, list) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003899 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %d rts threshold %d\n",
Michal Kaziorad088bf2013-10-16 15:44:46 +03003900 arvif->vdev_id, value);
Kalle Valo60c3daa2013-09-08 17:56:07 +03003901
Michal Kaziorad088bf2013-10-16 15:44:46 +03003902 ret = ath10k_mac_set_rts(arvif, value);
3903 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003904 ath10k_warn(ar, "failed to set rts threshold for vdev %d: %d\n",
Michal Kaziorad088bf2013-10-16 15:44:46 +03003905 arvif->vdev_id, ret);
3906 break;
3907 }
3908 }
3909 mutex_unlock(&ar->conf_mutex);
3910
3911 return ret;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003912}
3913
3914static int ath10k_set_frag_threshold(struct ieee80211_hw *hw, u32 value)
3915{
Kalle Valo5e3dd152013-06-12 20:52:10 +03003916 struct ath10k *ar = hw->priv;
Michal Kaziorad088bf2013-10-16 15:44:46 +03003917 struct ath10k_vif *arvif;
3918 int ret = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003919
Kalle Valo5e3dd152013-06-12 20:52:10 +03003920 mutex_lock(&ar->conf_mutex);
Michal Kaziorad088bf2013-10-16 15:44:46 +03003921 list_for_each_entry(arvif, &ar->arvifs, list) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003922 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %d fragmentation threshold %d\n",
Michal Kaziorad088bf2013-10-16 15:44:46 +03003923 arvif->vdev_id, value);
3924
Michal Kazior56a0dee2014-10-23 17:04:29 +03003925 ret = ath10k_mac_set_frag(arvif, value);
Michal Kaziorad088bf2013-10-16 15:44:46 +03003926 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003927 ath10k_warn(ar, "failed to set fragmentation threshold for vdev %d: %d\n",
Michal Kaziorad088bf2013-10-16 15:44:46 +03003928 arvif->vdev_id, ret);
3929 break;
3930 }
3931 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03003932 mutex_unlock(&ar->conf_mutex);
3933
Michal Kaziorad088bf2013-10-16 15:44:46 +03003934 return ret;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003935}
3936
Emmanuel Grumbach77be2c52014-03-27 11:30:29 +02003937static void ath10k_flush(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
3938 u32 queues, bool drop)
Kalle Valo5e3dd152013-06-12 20:52:10 +03003939{
3940 struct ath10k *ar = hw->priv;
Michal Kazioraffd3212013-07-16 09:54:35 +02003941 bool skip;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003942 int ret;
3943
3944 /* mac80211 doesn't care if we really xmit queued frames or not
3945 * we'll collect those frames either way if we stop/delete vdevs */
3946 if (drop)
3947 return;
3948
Michal Kazior548db542013-07-05 16:15:15 +03003949 mutex_lock(&ar->conf_mutex);
3950
Michal Kazioraffd3212013-07-16 09:54:35 +02003951 if (ar->state == ATH10K_STATE_WEDGED)
3952 goto skip;
3953
Michal Kazioredb82362013-07-05 16:15:14 +03003954 ret = wait_event_timeout(ar->htt.empty_tx_wq, ({
Kalle Valo5e3dd152013-06-12 20:52:10 +03003955 bool empty;
Michal Kazioraffd3212013-07-16 09:54:35 +02003956
Michal Kazioredb82362013-07-05 16:15:14 +03003957 spin_lock_bh(&ar->htt.tx_lock);
Michal Kazior0945baf2013-09-18 14:43:18 +02003958 empty = (ar->htt.num_pending_tx == 0);
Michal Kazioredb82362013-07-05 16:15:14 +03003959 spin_unlock_bh(&ar->htt.tx_lock);
Michal Kazioraffd3212013-07-16 09:54:35 +02003960
Michal Kazior7962b0d2014-10-28 10:34:38 +01003961 skip = (ar->state == ATH10K_STATE_WEDGED) ||
3962 test_bit(ATH10K_FLAG_CRASH_FLUSH,
3963 &ar->dev_flags);
Michal Kazioraffd3212013-07-16 09:54:35 +02003964
3965 (empty || skip);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003966 }), ATH10K_FLUSH_TIMEOUT_HZ);
Michal Kazioraffd3212013-07-16 09:54:35 +02003967
3968 if (ret <= 0 || skip)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003969 ath10k_warn(ar, "failed to flush transmit queue (skip %i ar-state %i): %i\n",
Ben Greear9ba4c782014-02-25 09:29:57 +02003970 skip, ar->state, ret);
Michal Kazior548db542013-07-05 16:15:15 +03003971
Michal Kazioraffd3212013-07-16 09:54:35 +02003972skip:
Michal Kazior548db542013-07-05 16:15:15 +03003973 mutex_unlock(&ar->conf_mutex);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003974}
3975
3976/* TODO: Implement this function properly
3977 * For now it is needed to reply to Probe Requests in IBSS mode.
3978 * Propably we need this information from FW.
3979 */
3980static int ath10k_tx_last_beacon(struct ieee80211_hw *hw)
3981{
3982 return 1;
3983}
3984
Michal Kazior8cd13ca2013-07-16 09:38:54 +02003985#ifdef CONFIG_PM
3986static int ath10k_suspend(struct ieee80211_hw *hw,
3987 struct cfg80211_wowlan *wowlan)
3988{
3989 struct ath10k *ar = hw->priv;
3990 int ret;
3991
Marek Puzyniak9042e172014-02-10 17:14:23 +01003992 mutex_lock(&ar->conf_mutex);
3993
Marek Puzyniak00f54822014-02-10 17:14:24 +01003994 ret = ath10k_wait_for_suspend(ar, WMI_PDEV_SUSPEND);
Michal Kazior8cd13ca2013-07-16 09:38:54 +02003995 if (ret) {
Marek Puzyniak00f54822014-02-10 17:14:24 +01003996 if (ret == -ETIMEDOUT)
3997 goto resume;
Marek Puzyniak9042e172014-02-10 17:14:23 +01003998 ret = 1;
3999 goto exit;
Michal Kazior8cd13ca2013-07-16 09:38:54 +02004000 }
4001
Michal Kazior8cd13ca2013-07-16 09:38:54 +02004002 ret = ath10k_hif_suspend(ar);
4003 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004004 ath10k_warn(ar, "failed to suspend hif: %d\n", ret);
Michal Kazior8cd13ca2013-07-16 09:38:54 +02004005 goto resume;
4006 }
4007
Marek Puzyniak9042e172014-02-10 17:14:23 +01004008 ret = 0;
4009 goto exit;
Michal Kazior8cd13ca2013-07-16 09:38:54 +02004010resume:
4011 ret = ath10k_wmi_pdev_resume_target(ar);
4012 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02004013 ath10k_warn(ar, "failed to resume target: %d\n", ret);
Marek Puzyniak9042e172014-02-10 17:14:23 +01004014
4015 ret = 1;
4016exit:
4017 mutex_unlock(&ar->conf_mutex);
4018 return ret;
Michal Kazior8cd13ca2013-07-16 09:38:54 +02004019}
4020
4021static int ath10k_resume(struct ieee80211_hw *hw)
4022{
4023 struct ath10k *ar = hw->priv;
4024 int ret;
4025
Marek Puzyniak9042e172014-02-10 17:14:23 +01004026 mutex_lock(&ar->conf_mutex);
4027
Michal Kazior8cd13ca2013-07-16 09:38:54 +02004028 ret = ath10k_hif_resume(ar);
4029 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004030 ath10k_warn(ar, "failed to resume hif: %d\n", ret);
Marek Puzyniak9042e172014-02-10 17:14:23 +01004031 ret = 1;
4032 goto exit;
Michal Kazior8cd13ca2013-07-16 09:38:54 +02004033 }
4034
4035 ret = ath10k_wmi_pdev_resume_target(ar);
4036 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004037 ath10k_warn(ar, "failed to resume target: %d\n", ret);
Marek Puzyniak9042e172014-02-10 17:14:23 +01004038 ret = 1;
4039 goto exit;
Michal Kazior8cd13ca2013-07-16 09:38:54 +02004040 }
4041
Marek Puzyniak9042e172014-02-10 17:14:23 +01004042 ret = 0;
4043exit:
4044 mutex_unlock(&ar->conf_mutex);
4045 return ret;
Michal Kazior8cd13ca2013-07-16 09:38:54 +02004046}
4047#endif
4048
Eliad Pellercf2c92d2014-11-04 11:43:54 +02004049static void ath10k_reconfig_complete(struct ieee80211_hw *hw,
4050 enum ieee80211_reconfig_type reconfig_type)
Michal Kazioraffd3212013-07-16 09:54:35 +02004051{
4052 struct ath10k *ar = hw->priv;
4053
Eliad Pellercf2c92d2014-11-04 11:43:54 +02004054 if (reconfig_type != IEEE80211_RECONFIG_TYPE_RESTART)
4055 return;
4056
Michal Kazioraffd3212013-07-16 09:54:35 +02004057 mutex_lock(&ar->conf_mutex);
4058
4059 /* If device failed to restart it will be in a different state, e.g.
4060 * ATH10K_STATE_WEDGED */
4061 if (ar->state == ATH10K_STATE_RESTARTED) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004062 ath10k_info(ar, "device successfully recovered\n");
Michal Kazioraffd3212013-07-16 09:54:35 +02004063 ar->state = ATH10K_STATE_ON;
Michal Kazior7962b0d2014-10-28 10:34:38 +01004064 ieee80211_wake_queues(ar->hw);
Michal Kazioraffd3212013-07-16 09:54:35 +02004065 }
4066
4067 mutex_unlock(&ar->conf_mutex);
4068}
4069
Michal Kazior2e1dea42013-07-31 10:32:40 +02004070static int ath10k_get_survey(struct ieee80211_hw *hw, int idx,
4071 struct survey_info *survey)
4072{
4073 struct ath10k *ar = hw->priv;
4074 struct ieee80211_supported_band *sband;
4075 struct survey_info *ar_survey = &ar->survey[idx];
4076 int ret = 0;
4077
4078 mutex_lock(&ar->conf_mutex);
4079
4080 sband = hw->wiphy->bands[IEEE80211_BAND_2GHZ];
4081 if (sband && idx >= sband->n_channels) {
4082 idx -= sband->n_channels;
4083 sband = NULL;
4084 }
4085
4086 if (!sband)
4087 sband = hw->wiphy->bands[IEEE80211_BAND_5GHZ];
4088
4089 if (!sband || idx >= sband->n_channels) {
4090 ret = -ENOENT;
4091 goto exit;
4092 }
4093
4094 spin_lock_bh(&ar->data_lock);
4095 memcpy(survey, ar_survey, sizeof(*survey));
4096 spin_unlock_bh(&ar->data_lock);
4097
4098 survey->channel = &sband->channels[idx];
4099
Felix Fietkaufa1d4df2014-10-23 17:04:28 +03004100 if (ar->rx_channel == survey->channel)
4101 survey->filled |= SURVEY_INFO_IN_USE;
4102
Michal Kazior2e1dea42013-07-31 10:32:40 +02004103exit:
4104 mutex_unlock(&ar->conf_mutex);
4105 return ret;
4106}
4107
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01004108/* Helper table for legacy fixed_rate/bitrate_mask */
4109static const u8 cck_ofdm_rate[] = {
4110 /* CCK */
4111 3, /* 1Mbps */
4112 2, /* 2Mbps */
4113 1, /* 5.5Mbps */
4114 0, /* 11Mbps */
4115 /* OFDM */
4116 3, /* 6Mbps */
4117 7, /* 9Mbps */
4118 2, /* 12Mbps */
4119 6, /* 18Mbps */
4120 1, /* 24Mbps */
4121 5, /* 36Mbps */
4122 0, /* 48Mbps */
4123 4, /* 54Mbps */
4124};
4125
4126/* Check if only one bit set */
4127static int ath10k_check_single_mask(u32 mask)
4128{
4129 int bit;
4130
4131 bit = ffs(mask);
4132 if (!bit)
4133 return 0;
4134
4135 mask &= ~BIT(bit - 1);
4136 if (mask)
4137 return 2;
4138
4139 return 1;
4140}
4141
4142static bool
4143ath10k_default_bitrate_mask(struct ath10k *ar,
4144 enum ieee80211_band band,
4145 const struct cfg80211_bitrate_mask *mask)
4146{
4147 u32 legacy = 0x00ff;
4148 u8 ht = 0xff, i;
4149 u16 vht = 0x3ff;
4150
4151 switch (band) {
4152 case IEEE80211_BAND_2GHZ:
4153 legacy = 0x00fff;
4154 vht = 0;
4155 break;
4156 case IEEE80211_BAND_5GHZ:
4157 break;
4158 default:
4159 return false;
4160 }
4161
4162 if (mask->control[band].legacy != legacy)
4163 return false;
4164
4165 for (i = 0; i < ar->num_rf_chains; i++)
4166 if (mask->control[band].ht_mcs[i] != ht)
4167 return false;
4168
4169 for (i = 0; i < ar->num_rf_chains; i++)
4170 if (mask->control[band].vht_mcs[i] != vht)
4171 return false;
4172
4173 return true;
4174}
4175
4176static bool
4177ath10k_bitrate_mask_nss(const struct cfg80211_bitrate_mask *mask,
4178 enum ieee80211_band band,
4179 u8 *fixed_nss)
4180{
4181 int ht_nss = 0, vht_nss = 0, i;
4182
4183 /* check legacy */
4184 if (ath10k_check_single_mask(mask->control[band].legacy))
4185 return false;
4186
4187 /* check HT */
4188 for (i = 0; i < IEEE80211_HT_MCS_MASK_LEN; i++) {
4189 if (mask->control[band].ht_mcs[i] == 0xff)
4190 continue;
4191 else if (mask->control[band].ht_mcs[i] == 0x00)
4192 break;
Kalle Valod8bb26b2014-09-14 12:50:33 +03004193
4194 return false;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01004195 }
4196
4197 ht_nss = i;
4198
4199 /* check VHT */
4200 for (i = 0; i < NL80211_VHT_NSS_MAX; i++) {
4201 if (mask->control[band].vht_mcs[i] == 0x03ff)
4202 continue;
4203 else if (mask->control[band].vht_mcs[i] == 0x0000)
4204 break;
Kalle Valod8bb26b2014-09-14 12:50:33 +03004205
4206 return false;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01004207 }
4208
4209 vht_nss = i;
4210
4211 if (ht_nss > 0 && vht_nss > 0)
4212 return false;
4213
4214 if (ht_nss)
4215 *fixed_nss = ht_nss;
4216 else if (vht_nss)
4217 *fixed_nss = vht_nss;
4218 else
4219 return false;
4220
4221 return true;
4222}
4223
4224static bool
4225ath10k_bitrate_mask_correct(const struct cfg80211_bitrate_mask *mask,
4226 enum ieee80211_band band,
4227 enum wmi_rate_preamble *preamble)
4228{
4229 int legacy = 0, ht = 0, vht = 0, i;
4230
4231 *preamble = WMI_RATE_PREAMBLE_OFDM;
4232
4233 /* check legacy */
4234 legacy = ath10k_check_single_mask(mask->control[band].legacy);
4235 if (legacy > 1)
4236 return false;
4237
4238 /* check HT */
4239 for (i = 0; i < IEEE80211_HT_MCS_MASK_LEN; i++)
4240 ht += ath10k_check_single_mask(mask->control[band].ht_mcs[i]);
4241 if (ht > 1)
4242 return false;
4243
4244 /* check VHT */
4245 for (i = 0; i < NL80211_VHT_NSS_MAX; i++)
4246 vht += ath10k_check_single_mask(mask->control[band].vht_mcs[i]);
4247 if (vht > 1)
4248 return false;
4249
4250 /* Currently we support only one fixed_rate */
4251 if ((legacy + ht + vht) != 1)
4252 return false;
4253
4254 if (ht)
4255 *preamble = WMI_RATE_PREAMBLE_HT;
4256 else if (vht)
4257 *preamble = WMI_RATE_PREAMBLE_VHT;
4258
4259 return true;
4260}
4261
4262static bool
Michal Kazior7aa7a722014-08-25 12:09:38 +02004263ath10k_bitrate_mask_rate(struct ath10k *ar,
4264 const struct cfg80211_bitrate_mask *mask,
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01004265 enum ieee80211_band band,
4266 u8 *fixed_rate,
4267 u8 *fixed_nss)
4268{
4269 u8 rate = 0, pream = 0, nss = 0, i;
4270 enum wmi_rate_preamble preamble;
4271
4272 /* Check if single rate correct */
4273 if (!ath10k_bitrate_mask_correct(mask, band, &preamble))
4274 return false;
4275
4276 pream = preamble;
4277
4278 switch (preamble) {
4279 case WMI_RATE_PREAMBLE_CCK:
4280 case WMI_RATE_PREAMBLE_OFDM:
4281 i = ffs(mask->control[band].legacy) - 1;
4282
4283 if (band == IEEE80211_BAND_2GHZ && i < 4)
4284 pream = WMI_RATE_PREAMBLE_CCK;
4285
4286 if (band == IEEE80211_BAND_5GHZ)
4287 i += 4;
4288
4289 if (i >= ARRAY_SIZE(cck_ofdm_rate))
4290 return false;
4291
4292 rate = cck_ofdm_rate[i];
4293 break;
4294 case WMI_RATE_PREAMBLE_HT:
4295 for (i = 0; i < IEEE80211_HT_MCS_MASK_LEN; i++)
4296 if (mask->control[band].ht_mcs[i])
4297 break;
4298
4299 if (i == IEEE80211_HT_MCS_MASK_LEN)
4300 return false;
4301
4302 rate = ffs(mask->control[band].ht_mcs[i]) - 1;
4303 nss = i;
4304 break;
4305 case WMI_RATE_PREAMBLE_VHT:
4306 for (i = 0; i < NL80211_VHT_NSS_MAX; i++)
4307 if (mask->control[band].vht_mcs[i])
4308 break;
4309
4310 if (i == NL80211_VHT_NSS_MAX)
4311 return false;
4312
4313 rate = ffs(mask->control[band].vht_mcs[i]) - 1;
4314 nss = i;
4315 break;
4316 }
4317
4318 *fixed_nss = nss + 1;
4319 nss <<= 4;
4320 pream <<= 6;
4321
Michal Kazior7aa7a722014-08-25 12:09:38 +02004322 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac fixed rate pream 0x%02x nss 0x%02x rate 0x%02x\n",
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01004323 pream, nss, rate);
4324
4325 *fixed_rate = pream | nss | rate;
4326
4327 return true;
4328}
4329
Michal Kazior7aa7a722014-08-25 12:09:38 +02004330static bool ath10k_get_fixed_rate_nss(struct ath10k *ar,
4331 const struct cfg80211_bitrate_mask *mask,
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01004332 enum ieee80211_band band,
4333 u8 *fixed_rate,
4334 u8 *fixed_nss)
4335{
4336 /* First check full NSS mask, if we can simply limit NSS */
4337 if (ath10k_bitrate_mask_nss(mask, band, fixed_nss))
4338 return true;
4339
4340 /* Next Check single rate is set */
Michal Kazior7aa7a722014-08-25 12:09:38 +02004341 return ath10k_bitrate_mask_rate(ar, mask, band, fixed_rate, fixed_nss);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01004342}
4343
4344static int ath10k_set_fixed_rate_param(struct ath10k_vif *arvif,
4345 u8 fixed_rate,
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01004346 u8 fixed_nss,
4347 u8 force_sgi)
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01004348{
4349 struct ath10k *ar = arvif->ar;
4350 u32 vdev_param;
4351 int ret = 0;
4352
4353 mutex_lock(&ar->conf_mutex);
4354
4355 if (arvif->fixed_rate == fixed_rate &&
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01004356 arvif->fixed_nss == fixed_nss &&
4357 arvif->force_sgi == force_sgi)
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01004358 goto exit;
4359
4360 if (fixed_rate == WMI_FIXED_RATE_NONE)
Michal Kazior7aa7a722014-08-25 12:09:38 +02004361 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac disable fixed bitrate mask\n");
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01004362
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01004363 if (force_sgi)
Michal Kazior7aa7a722014-08-25 12:09:38 +02004364 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac force sgi\n");
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01004365
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01004366 vdev_param = ar->wmi.vdev_param->fixed_rate;
4367 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id,
4368 vdev_param, fixed_rate);
4369 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004370 ath10k_warn(ar, "failed to set fixed rate param 0x%02x: %d\n",
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01004371 fixed_rate, ret);
4372 ret = -EINVAL;
4373 goto exit;
4374 }
4375
4376 arvif->fixed_rate = fixed_rate;
4377
4378 vdev_param = ar->wmi.vdev_param->nss;
4379 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id,
4380 vdev_param, fixed_nss);
4381
4382 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004383 ath10k_warn(ar, "failed to set fixed nss param %d: %d\n",
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01004384 fixed_nss, ret);
4385 ret = -EINVAL;
4386 goto exit;
4387 }
4388
4389 arvif->fixed_nss = fixed_nss;
4390
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01004391 vdev_param = ar->wmi.vdev_param->sgi;
4392 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
4393 force_sgi);
4394
4395 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004396 ath10k_warn(ar, "failed to set sgi param %d: %d\n",
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01004397 force_sgi, ret);
4398 ret = -EINVAL;
4399 goto exit;
4400 }
4401
4402 arvif->force_sgi = force_sgi;
4403
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01004404exit:
4405 mutex_unlock(&ar->conf_mutex);
4406 return ret;
4407}
4408
4409static int ath10k_set_bitrate_mask(struct ieee80211_hw *hw,
4410 struct ieee80211_vif *vif,
4411 const struct cfg80211_bitrate_mask *mask)
4412{
4413 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
4414 struct ath10k *ar = arvif->ar;
4415 enum ieee80211_band band = ar->hw->conf.chandef.chan->band;
4416 u8 fixed_rate = WMI_FIXED_RATE_NONE;
4417 u8 fixed_nss = ar->num_rf_chains;
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01004418 u8 force_sgi;
4419
4420 force_sgi = mask->control[band].gi;
4421 if (force_sgi == NL80211_TXRATE_FORCE_LGI)
4422 return -EINVAL;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01004423
4424 if (!ath10k_default_bitrate_mask(ar, band, mask)) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004425 if (!ath10k_get_fixed_rate_nss(ar, mask, band,
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01004426 &fixed_rate,
4427 &fixed_nss))
4428 return -EINVAL;
4429 }
4430
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01004431 if (fixed_rate == WMI_FIXED_RATE_NONE && force_sgi) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004432 ath10k_warn(ar, "failed to force SGI usage for default rate settings\n");
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01004433 return -EINVAL;
4434 }
4435
4436 return ath10k_set_fixed_rate_param(arvif, fixed_rate,
4437 fixed_nss, force_sgi);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01004438}
4439
Michal Kazior9797feb2014-02-14 14:49:48 +01004440static void ath10k_sta_rc_update(struct ieee80211_hw *hw,
4441 struct ieee80211_vif *vif,
4442 struct ieee80211_sta *sta,
4443 u32 changed)
4444{
4445 struct ath10k *ar = hw->priv;
4446 struct ath10k_sta *arsta = (struct ath10k_sta *)sta->drv_priv;
4447 u32 bw, smps;
4448
4449 spin_lock_bh(&ar->data_lock);
4450
Michal Kazior7aa7a722014-08-25 12:09:38 +02004451 ath10k_dbg(ar, ATH10K_DBG_MAC,
Michal Kazior9797feb2014-02-14 14:49:48 +01004452 "mac sta rc update for %pM changed %08x bw %d nss %d smps %d\n",
4453 sta->addr, changed, sta->bandwidth, sta->rx_nss,
4454 sta->smps_mode);
4455
4456 if (changed & IEEE80211_RC_BW_CHANGED) {
4457 bw = WMI_PEER_CHWIDTH_20MHZ;
4458
4459 switch (sta->bandwidth) {
4460 case IEEE80211_STA_RX_BW_20:
4461 bw = WMI_PEER_CHWIDTH_20MHZ;
4462 break;
4463 case IEEE80211_STA_RX_BW_40:
4464 bw = WMI_PEER_CHWIDTH_40MHZ;
4465 break;
4466 case IEEE80211_STA_RX_BW_80:
4467 bw = WMI_PEER_CHWIDTH_80MHZ;
4468 break;
4469 case IEEE80211_STA_RX_BW_160:
Michal Kazior7aa7a722014-08-25 12:09:38 +02004470 ath10k_warn(ar, "Invalid bandwith %d in rc update for %pM\n",
Kalle Valobe6546f2014-03-25 14:18:51 +02004471 sta->bandwidth, sta->addr);
Michal Kazior9797feb2014-02-14 14:49:48 +01004472 bw = WMI_PEER_CHWIDTH_20MHZ;
4473 break;
4474 }
4475
4476 arsta->bw = bw;
4477 }
4478
4479 if (changed & IEEE80211_RC_NSS_CHANGED)
4480 arsta->nss = sta->rx_nss;
4481
4482 if (changed & IEEE80211_RC_SMPS_CHANGED) {
4483 smps = WMI_PEER_SMPS_PS_NONE;
4484
4485 switch (sta->smps_mode) {
4486 case IEEE80211_SMPS_AUTOMATIC:
4487 case IEEE80211_SMPS_OFF:
4488 smps = WMI_PEER_SMPS_PS_NONE;
4489 break;
4490 case IEEE80211_SMPS_STATIC:
4491 smps = WMI_PEER_SMPS_STATIC;
4492 break;
4493 case IEEE80211_SMPS_DYNAMIC:
4494 smps = WMI_PEER_SMPS_DYNAMIC;
4495 break;
4496 case IEEE80211_SMPS_NUM_MODES:
Michal Kazior7aa7a722014-08-25 12:09:38 +02004497 ath10k_warn(ar, "Invalid smps %d in sta rc update for %pM\n",
Kalle Valobe6546f2014-03-25 14:18:51 +02004498 sta->smps_mode, sta->addr);
Michal Kazior9797feb2014-02-14 14:49:48 +01004499 smps = WMI_PEER_SMPS_PS_NONE;
4500 break;
4501 }
4502
4503 arsta->smps = smps;
4504 }
4505
Michal Kazior9797feb2014-02-14 14:49:48 +01004506 arsta->changed |= changed;
4507
4508 spin_unlock_bh(&ar->data_lock);
4509
4510 ieee80211_queue_work(hw, &arsta->update_wk);
4511}
4512
Chun-Yeow Yeoh26ebbcc2014-02-25 09:29:54 +02004513static u64 ath10k_get_tsf(struct ieee80211_hw *hw, struct ieee80211_vif *vif)
4514{
4515 /*
4516 * FIXME: Return 0 for time being. Need to figure out whether FW
4517 * has the API to fetch 64-bit local TSF
4518 */
4519
4520 return 0;
4521}
4522
Michal Kazioraa5b4fb2014-07-23 12:20:33 +02004523static int ath10k_ampdu_action(struct ieee80211_hw *hw,
4524 struct ieee80211_vif *vif,
4525 enum ieee80211_ampdu_mlme_action action,
4526 struct ieee80211_sta *sta, u16 tid, u16 *ssn,
4527 u8 buf_size)
4528{
Michal Kazior7aa7a722014-08-25 12:09:38 +02004529 struct ath10k *ar = hw->priv;
Michal Kazioraa5b4fb2014-07-23 12:20:33 +02004530 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
4531
Michal Kazior7aa7a722014-08-25 12:09:38 +02004532 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac ampdu vdev_id %i sta %pM tid %hu action %d\n",
Michal Kazioraa5b4fb2014-07-23 12:20:33 +02004533 arvif->vdev_id, sta->addr, tid, action);
4534
4535 switch (action) {
4536 case IEEE80211_AMPDU_RX_START:
4537 case IEEE80211_AMPDU_RX_STOP:
4538 /* HTT AddBa/DelBa events trigger mac80211 Rx BA session
4539 * creation/removal. Do we need to verify this?
4540 */
4541 return 0;
4542 case IEEE80211_AMPDU_TX_START:
4543 case IEEE80211_AMPDU_TX_STOP_CONT:
4544 case IEEE80211_AMPDU_TX_STOP_FLUSH:
4545 case IEEE80211_AMPDU_TX_STOP_FLUSH_CONT:
4546 case IEEE80211_AMPDU_TX_OPERATIONAL:
4547 /* Firmware offloads Tx aggregation entirely so deny mac80211
4548 * Tx aggregation requests.
4549 */
4550 return -EOPNOTSUPP;
4551 }
4552
4553 return -EINVAL;
4554}
4555
Kalle Valo5e3dd152013-06-12 20:52:10 +03004556static const struct ieee80211_ops ath10k_ops = {
4557 .tx = ath10k_tx,
4558 .start = ath10k_start,
4559 .stop = ath10k_stop,
4560 .config = ath10k_config,
4561 .add_interface = ath10k_add_interface,
4562 .remove_interface = ath10k_remove_interface,
4563 .configure_filter = ath10k_configure_filter,
4564 .bss_info_changed = ath10k_bss_info_changed,
4565 .hw_scan = ath10k_hw_scan,
4566 .cancel_hw_scan = ath10k_cancel_hw_scan,
4567 .set_key = ath10k_set_key,
4568 .sta_state = ath10k_sta_state,
4569 .conf_tx = ath10k_conf_tx,
4570 .remain_on_channel = ath10k_remain_on_channel,
4571 .cancel_remain_on_channel = ath10k_cancel_remain_on_channel,
4572 .set_rts_threshold = ath10k_set_rts_threshold,
4573 .set_frag_threshold = ath10k_set_frag_threshold,
4574 .flush = ath10k_flush,
4575 .tx_last_beacon = ath10k_tx_last_beacon,
Ben Greear46acf7b2014-05-16 17:15:38 +03004576 .set_antenna = ath10k_set_antenna,
4577 .get_antenna = ath10k_get_antenna,
Eliad Pellercf2c92d2014-11-04 11:43:54 +02004578 .reconfig_complete = ath10k_reconfig_complete,
Michal Kazior2e1dea42013-07-31 10:32:40 +02004579 .get_survey = ath10k_get_survey,
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01004580 .set_bitrate_mask = ath10k_set_bitrate_mask,
Michal Kazior9797feb2014-02-14 14:49:48 +01004581 .sta_rc_update = ath10k_sta_rc_update,
Chun-Yeow Yeoh26ebbcc2014-02-25 09:29:54 +02004582 .get_tsf = ath10k_get_tsf,
Michal Kazioraa5b4fb2014-07-23 12:20:33 +02004583 .ampdu_action = ath10k_ampdu_action,
Ben Greear6cddcc72014-09-29 14:41:46 +03004584 .get_et_sset_count = ath10k_debug_get_et_sset_count,
4585 .get_et_stats = ath10k_debug_get_et_stats,
4586 .get_et_strings = ath10k_debug_get_et_strings,
Kalle Valo43d2a302014-09-10 18:23:30 +03004587
4588 CFG80211_TESTMODE_CMD(ath10k_tm_cmd)
4589
Michal Kazior8cd13ca2013-07-16 09:38:54 +02004590#ifdef CONFIG_PM
4591 .suspend = ath10k_suspend,
4592 .resume = ath10k_resume,
4593#endif
Kalle Valo5e3dd152013-06-12 20:52:10 +03004594};
4595
4596#define RATETAB_ENT(_rate, _rateid, _flags) { \
4597 .bitrate = (_rate), \
4598 .flags = (_flags), \
4599 .hw_value = (_rateid), \
4600}
4601
4602#define CHAN2G(_channel, _freq, _flags) { \
4603 .band = IEEE80211_BAND_2GHZ, \
4604 .hw_value = (_channel), \
4605 .center_freq = (_freq), \
4606 .flags = (_flags), \
4607 .max_antenna_gain = 0, \
4608 .max_power = 30, \
4609}
4610
4611#define CHAN5G(_channel, _freq, _flags) { \
4612 .band = IEEE80211_BAND_5GHZ, \
4613 .hw_value = (_channel), \
4614 .center_freq = (_freq), \
4615 .flags = (_flags), \
4616 .max_antenna_gain = 0, \
4617 .max_power = 30, \
4618}
4619
4620static const struct ieee80211_channel ath10k_2ghz_channels[] = {
4621 CHAN2G(1, 2412, 0),
4622 CHAN2G(2, 2417, 0),
4623 CHAN2G(3, 2422, 0),
4624 CHAN2G(4, 2427, 0),
4625 CHAN2G(5, 2432, 0),
4626 CHAN2G(6, 2437, 0),
4627 CHAN2G(7, 2442, 0),
4628 CHAN2G(8, 2447, 0),
4629 CHAN2G(9, 2452, 0),
4630 CHAN2G(10, 2457, 0),
4631 CHAN2G(11, 2462, 0),
4632 CHAN2G(12, 2467, 0),
4633 CHAN2G(13, 2472, 0),
4634 CHAN2G(14, 2484, 0),
4635};
4636
4637static const struct ieee80211_channel ath10k_5ghz_channels[] = {
Michal Kazior429ff562013-06-26 08:54:54 +02004638 CHAN5G(36, 5180, 0),
4639 CHAN5G(40, 5200, 0),
4640 CHAN5G(44, 5220, 0),
4641 CHAN5G(48, 5240, 0),
4642 CHAN5G(52, 5260, 0),
4643 CHAN5G(56, 5280, 0),
4644 CHAN5G(60, 5300, 0),
4645 CHAN5G(64, 5320, 0),
4646 CHAN5G(100, 5500, 0),
4647 CHAN5G(104, 5520, 0),
4648 CHAN5G(108, 5540, 0),
4649 CHAN5G(112, 5560, 0),
4650 CHAN5G(116, 5580, 0),
4651 CHAN5G(120, 5600, 0),
4652 CHAN5G(124, 5620, 0),
4653 CHAN5G(128, 5640, 0),
4654 CHAN5G(132, 5660, 0),
4655 CHAN5G(136, 5680, 0),
4656 CHAN5G(140, 5700, 0),
4657 CHAN5G(149, 5745, 0),
4658 CHAN5G(153, 5765, 0),
4659 CHAN5G(157, 5785, 0),
4660 CHAN5G(161, 5805, 0),
4661 CHAN5G(165, 5825, 0),
Kalle Valo5e3dd152013-06-12 20:52:10 +03004662};
4663
4664static struct ieee80211_rate ath10k_rates[] = {
4665 /* CCK */
4666 RATETAB_ENT(10, 0x82, 0),
4667 RATETAB_ENT(20, 0x84, 0),
4668 RATETAB_ENT(55, 0x8b, 0),
4669 RATETAB_ENT(110, 0x96, 0),
4670 /* OFDM */
4671 RATETAB_ENT(60, 0x0c, 0),
4672 RATETAB_ENT(90, 0x12, 0),
4673 RATETAB_ENT(120, 0x18, 0),
4674 RATETAB_ENT(180, 0x24, 0),
4675 RATETAB_ENT(240, 0x30, 0),
4676 RATETAB_ENT(360, 0x48, 0),
4677 RATETAB_ENT(480, 0x60, 0),
4678 RATETAB_ENT(540, 0x6c, 0),
4679};
4680
4681#define ath10k_a_rates (ath10k_rates + 4)
4682#define ath10k_a_rates_size (ARRAY_SIZE(ath10k_rates) - 4)
4683#define ath10k_g_rates (ath10k_rates + 0)
4684#define ath10k_g_rates_size (ARRAY_SIZE(ath10k_rates))
4685
Michal Kaziore7b54192014-08-07 11:03:27 +02004686struct ath10k *ath10k_mac_create(size_t priv_size)
Kalle Valo5e3dd152013-06-12 20:52:10 +03004687{
4688 struct ieee80211_hw *hw;
4689 struct ath10k *ar;
4690
Michal Kaziore7b54192014-08-07 11:03:27 +02004691 hw = ieee80211_alloc_hw(sizeof(struct ath10k) + priv_size, &ath10k_ops);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004692 if (!hw)
4693 return NULL;
4694
4695 ar = hw->priv;
4696 ar->hw = hw;
4697
4698 return ar;
4699}
4700
4701void ath10k_mac_destroy(struct ath10k *ar)
4702{
4703 ieee80211_free_hw(ar->hw);
4704}
4705
4706static const struct ieee80211_iface_limit ath10k_if_limits[] = {
4707 {
4708 .max = 8,
4709 .types = BIT(NL80211_IFTYPE_STATION)
4710 | BIT(NL80211_IFTYPE_P2P_CLIENT)
Michal Kaziord531cb82013-07-31 10:55:13 +02004711 },
4712 {
4713 .max = 3,
4714 .types = BIT(NL80211_IFTYPE_P2P_GO)
4715 },
4716 {
4717 .max = 7,
4718 .types = BIT(NL80211_IFTYPE_AP)
4719 },
Kalle Valo5e3dd152013-06-12 20:52:10 +03004720};
4721
Bartosz Markowskif2595092013-12-10 16:20:39 +01004722static const struct ieee80211_iface_limit ath10k_10x_if_limits[] = {
Marek Puzyniake8a50f82013-11-20 09:59:47 +02004723 {
4724 .max = 8,
4725 .types = BIT(NL80211_IFTYPE_AP)
4726 },
4727};
Marek Puzyniake8a50f82013-11-20 09:59:47 +02004728
4729static const struct ieee80211_iface_combination ath10k_if_comb[] = {
4730 {
4731 .limits = ath10k_if_limits,
4732 .n_limits = ARRAY_SIZE(ath10k_if_limits),
4733 .max_interfaces = 8,
4734 .num_different_channels = 1,
4735 .beacon_int_infra_match = true,
4736 },
Bartosz Markowskif2595092013-12-10 16:20:39 +01004737};
4738
4739static const struct ieee80211_iface_combination ath10k_10x_if_comb[] = {
Marek Puzyniake8a50f82013-11-20 09:59:47 +02004740 {
Bartosz Markowskif2595092013-12-10 16:20:39 +01004741 .limits = ath10k_10x_if_limits,
4742 .n_limits = ARRAY_SIZE(ath10k_10x_if_limits),
Marek Puzyniake8a50f82013-11-20 09:59:47 +02004743 .max_interfaces = 8,
4744 .num_different_channels = 1,
4745 .beacon_int_infra_match = true,
Bartosz Markowskif2595092013-12-10 16:20:39 +01004746#ifdef CONFIG_ATH10K_DFS_CERTIFIED
Marek Puzyniake8a50f82013-11-20 09:59:47 +02004747 .radar_detect_widths = BIT(NL80211_CHAN_WIDTH_20_NOHT) |
4748 BIT(NL80211_CHAN_WIDTH_20) |
4749 BIT(NL80211_CHAN_WIDTH_40) |
4750 BIT(NL80211_CHAN_WIDTH_80),
Marek Puzyniake8a50f82013-11-20 09:59:47 +02004751#endif
Bartosz Markowskif2595092013-12-10 16:20:39 +01004752 },
Kalle Valo5e3dd152013-06-12 20:52:10 +03004753};
4754
4755static struct ieee80211_sta_vht_cap ath10k_create_vht_cap(struct ath10k *ar)
4756{
4757 struct ieee80211_sta_vht_cap vht_cap = {0};
4758 u16 mcs_map;
Michal Kazior8865bee42013-07-24 12:36:46 +02004759 int i;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004760
4761 vht_cap.vht_supported = 1;
4762 vht_cap.cap = ar->vht_cap_info;
4763
Michal Kazior8865bee42013-07-24 12:36:46 +02004764 mcs_map = 0;
4765 for (i = 0; i < 8; i++) {
4766 if (i < ar->num_rf_chains)
4767 mcs_map |= IEEE80211_VHT_MCS_SUPPORT_0_9 << (i*2);
4768 else
4769 mcs_map |= IEEE80211_VHT_MCS_NOT_SUPPORTED << (i*2);
4770 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004771
4772 vht_cap.vht_mcs.rx_mcs_map = cpu_to_le16(mcs_map);
4773 vht_cap.vht_mcs.tx_mcs_map = cpu_to_le16(mcs_map);
4774
4775 return vht_cap;
4776}
4777
4778static struct ieee80211_sta_ht_cap ath10k_get_ht_cap(struct ath10k *ar)
4779{
4780 int i;
4781 struct ieee80211_sta_ht_cap ht_cap = {0};
4782
4783 if (!(ar->ht_cap_info & WMI_HT_CAP_ENABLED))
4784 return ht_cap;
4785
4786 ht_cap.ht_supported = 1;
4787 ht_cap.ampdu_factor = IEEE80211_HT_MAX_AMPDU_64K;
4788 ht_cap.ampdu_density = IEEE80211_HT_MPDU_DENSITY_8;
4789 ht_cap.cap |= IEEE80211_HT_CAP_SUP_WIDTH_20_40;
4790 ht_cap.cap |= IEEE80211_HT_CAP_DSSSCCK40;
4791 ht_cap.cap |= WLAN_HT_CAP_SM_PS_STATIC << IEEE80211_HT_CAP_SM_PS_SHIFT;
4792
4793 if (ar->ht_cap_info & WMI_HT_CAP_HT20_SGI)
4794 ht_cap.cap |= IEEE80211_HT_CAP_SGI_20;
4795
4796 if (ar->ht_cap_info & WMI_HT_CAP_HT40_SGI)
4797 ht_cap.cap |= IEEE80211_HT_CAP_SGI_40;
4798
4799 if (ar->ht_cap_info & WMI_HT_CAP_DYNAMIC_SMPS) {
4800 u32 smps;
4801
4802 smps = WLAN_HT_CAP_SM_PS_DYNAMIC;
4803 smps <<= IEEE80211_HT_CAP_SM_PS_SHIFT;
4804
4805 ht_cap.cap |= smps;
4806 }
4807
4808 if (ar->ht_cap_info & WMI_HT_CAP_TX_STBC)
4809 ht_cap.cap |= IEEE80211_HT_CAP_TX_STBC;
4810
4811 if (ar->ht_cap_info & WMI_HT_CAP_RX_STBC) {
4812 u32 stbc;
4813
4814 stbc = ar->ht_cap_info;
4815 stbc &= WMI_HT_CAP_RX_STBC;
4816 stbc >>= WMI_HT_CAP_RX_STBC_MASK_SHIFT;
4817 stbc <<= IEEE80211_HT_CAP_RX_STBC_SHIFT;
4818 stbc &= IEEE80211_HT_CAP_RX_STBC;
4819
4820 ht_cap.cap |= stbc;
4821 }
4822
4823 if (ar->ht_cap_info & WMI_HT_CAP_LDPC)
4824 ht_cap.cap |= IEEE80211_HT_CAP_LDPC_CODING;
4825
4826 if (ar->ht_cap_info & WMI_HT_CAP_L_SIG_TXOP_PROT)
4827 ht_cap.cap |= IEEE80211_HT_CAP_LSIG_TXOP_PROT;
4828
4829 /* max AMSDU is implicitly taken from vht_cap_info */
4830 if (ar->vht_cap_info & WMI_VHT_CAP_MAX_MPDU_LEN_MASK)
4831 ht_cap.cap |= IEEE80211_HT_CAP_MAX_AMSDU;
4832
Michal Kazior8865bee42013-07-24 12:36:46 +02004833 for (i = 0; i < ar->num_rf_chains; i++)
Kalle Valo5e3dd152013-06-12 20:52:10 +03004834 ht_cap.mcs.rx_mask[i] = 0xFF;
4835
4836 ht_cap.mcs.tx_params |= IEEE80211_HT_MCS_TX_DEFINED;
4837
4838 return ht_cap;
4839}
4840
Kalle Valo5e3dd152013-06-12 20:52:10 +03004841static void ath10k_get_arvif_iter(void *data, u8 *mac,
4842 struct ieee80211_vif *vif)
4843{
4844 struct ath10k_vif_iter *arvif_iter = data;
4845 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
4846
4847 if (arvif->vdev_id == arvif_iter->vdev_id)
4848 arvif_iter->arvif = arvif;
4849}
4850
4851struct ath10k_vif *ath10k_get_arvif(struct ath10k *ar, u32 vdev_id)
4852{
4853 struct ath10k_vif_iter arvif_iter;
4854 u32 flags;
4855
4856 memset(&arvif_iter, 0, sizeof(struct ath10k_vif_iter));
4857 arvif_iter.vdev_id = vdev_id;
4858
4859 flags = IEEE80211_IFACE_ITER_RESUME_ALL;
4860 ieee80211_iterate_active_interfaces_atomic(ar->hw,
4861 flags,
4862 ath10k_get_arvif_iter,
4863 &arvif_iter);
4864 if (!arvif_iter.arvif) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004865 ath10k_warn(ar, "No VIF found for vdev %d\n", vdev_id);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004866 return NULL;
4867 }
4868
4869 return arvif_iter.arvif;
4870}
4871
4872int ath10k_mac_register(struct ath10k *ar)
4873{
4874 struct ieee80211_supported_band *band;
4875 struct ieee80211_sta_vht_cap vht_cap;
4876 struct ieee80211_sta_ht_cap ht_cap;
4877 void *channels;
4878 int ret;
4879
4880 SET_IEEE80211_PERM_ADDR(ar->hw, ar->mac_addr);
4881
4882 SET_IEEE80211_DEV(ar->hw, ar->dev);
4883
4884 ht_cap = ath10k_get_ht_cap(ar);
4885 vht_cap = ath10k_create_vht_cap(ar);
4886
4887 if (ar->phy_capability & WHAL_WLAN_11G_CAPABILITY) {
4888 channels = kmemdup(ath10k_2ghz_channels,
4889 sizeof(ath10k_2ghz_channels),
4890 GFP_KERNEL);
Michal Kaziord6015b22013-07-22 14:13:30 +02004891 if (!channels) {
4892 ret = -ENOMEM;
4893 goto err_free;
4894 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004895
4896 band = &ar->mac.sbands[IEEE80211_BAND_2GHZ];
4897 band->n_channels = ARRAY_SIZE(ath10k_2ghz_channels);
4898 band->channels = channels;
4899 band->n_bitrates = ath10k_g_rates_size;
4900 band->bitrates = ath10k_g_rates;
4901 band->ht_cap = ht_cap;
4902
4903 /* vht is not supported in 2.4 GHz */
4904
4905 ar->hw->wiphy->bands[IEEE80211_BAND_2GHZ] = band;
4906 }
4907
4908 if (ar->phy_capability & WHAL_WLAN_11A_CAPABILITY) {
4909 channels = kmemdup(ath10k_5ghz_channels,
4910 sizeof(ath10k_5ghz_channels),
4911 GFP_KERNEL);
4912 if (!channels) {
Michal Kaziord6015b22013-07-22 14:13:30 +02004913 ret = -ENOMEM;
4914 goto err_free;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004915 }
4916
4917 band = &ar->mac.sbands[IEEE80211_BAND_5GHZ];
4918 band->n_channels = ARRAY_SIZE(ath10k_5ghz_channels);
4919 band->channels = channels;
4920 band->n_bitrates = ath10k_a_rates_size;
4921 band->bitrates = ath10k_a_rates;
4922 band->ht_cap = ht_cap;
4923 band->vht_cap = vht_cap;
4924 ar->hw->wiphy->bands[IEEE80211_BAND_5GHZ] = band;
4925 }
4926
4927 ar->hw->wiphy->interface_modes =
4928 BIT(NL80211_IFTYPE_STATION) |
Bartosz Markowskid3541812013-12-10 16:20:40 +01004929 BIT(NL80211_IFTYPE_AP);
4930
Ben Greear46acf7b2014-05-16 17:15:38 +03004931 ar->hw->wiphy->available_antennas_rx = ar->supp_rx_chainmask;
4932 ar->hw->wiphy->available_antennas_tx = ar->supp_tx_chainmask;
4933
Bartosz Markowskid3541812013-12-10 16:20:40 +01004934 if (!test_bit(ATH10K_FW_FEATURE_NO_P2P, ar->fw_features))
4935 ar->hw->wiphy->interface_modes |=
4936 BIT(NL80211_IFTYPE_P2P_CLIENT) |
4937 BIT(NL80211_IFTYPE_P2P_GO);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004938
4939 ar->hw->flags = IEEE80211_HW_SIGNAL_DBM |
4940 IEEE80211_HW_SUPPORTS_PS |
4941 IEEE80211_HW_SUPPORTS_DYNAMIC_PS |
4942 IEEE80211_HW_SUPPORTS_UAPSD |
4943 IEEE80211_HW_MFP_CAPABLE |
4944 IEEE80211_HW_REPORTS_TX_ACK_STATUS |
4945 IEEE80211_HW_HAS_RATE_CONTROL |
Janusz Dziedzic2f0f1122014-02-26 18:42:09 +02004946 IEEE80211_HW_AP_LINK_PS |
4947 IEEE80211_HW_SPECTRUM_MGMT;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004948
Michal Kazior1f8bb152013-09-18 14:43:22 +02004949 /* MSDU can have HTT TX fragment pushed in front. The additional 4
4950 * bytes is used for padding/alignment if necessary. */
4951 ar->hw->extra_tx_headroom += sizeof(struct htt_data_tx_desc_frag)*2 + 4;
4952
Eliad Peller0d8614b2014-09-10 14:07:36 +03004953 ar->hw->wiphy->features |= NL80211_FEATURE_STATIC_SMPS;
4954
Kalle Valo5e3dd152013-06-12 20:52:10 +03004955 if (ar->ht_cap_info & WMI_HT_CAP_DYNAMIC_SMPS)
Eliad Peller0d8614b2014-09-10 14:07:36 +03004956 ar->hw->wiphy->features |= NL80211_FEATURE_DYNAMIC_SMPS;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004957
4958 if (ar->ht_cap_info & WMI_HT_CAP_ENABLED) {
4959 ar->hw->flags |= IEEE80211_HW_AMPDU_AGGREGATION;
4960 ar->hw->flags |= IEEE80211_HW_TX_AMPDU_SETUP_IN_HW;
4961 }
4962
4963 ar->hw->wiphy->max_scan_ssids = WLAN_SCAN_PARAMS_MAX_SSID;
4964 ar->hw->wiphy->max_scan_ie_len = WLAN_SCAN_PARAMS_MAX_IE_LEN;
4965
4966 ar->hw->vif_data_size = sizeof(struct ath10k_vif);
Michal Kazior9797feb2014-02-14 14:49:48 +01004967 ar->hw->sta_data_size = sizeof(struct ath10k_sta);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004968
Kalle Valo5e3dd152013-06-12 20:52:10 +03004969 ar->hw->max_listen_interval = ATH10K_MAX_HW_LISTEN_INTERVAL;
4970
4971 ar->hw->wiphy->flags |= WIPHY_FLAG_HAS_REMAIN_ON_CHANNEL;
Michal Kaziorc2df44b2014-01-23 11:38:26 +01004972 ar->hw->wiphy->flags |= WIPHY_FLAG_HAS_CHANNEL_SWITCH;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004973 ar->hw->wiphy->max_remain_on_channel_duration = 5000;
4974
4975 ar->hw->wiphy->flags |= WIPHY_FLAG_AP_UAPSD;
Rajkumar Manoharan78157a12014-11-17 16:44:15 +02004976 ar->hw->wiphy->features |= NL80211_FEATURE_AP_MODE_CHAN_WIDTH_CHANGE;
4977
Kalle Valo5e3dd152013-06-12 20:52:10 +03004978 /*
4979 * on LL hardware queues are managed entirely by the FW
4980 * so we only advertise to mac we can do the queues thing
4981 */
4982 ar->hw->queues = 4;
4983
Bartosz Markowskif2595092013-12-10 16:20:39 +01004984 if (test_bit(ATH10K_FW_FEATURE_WMI_10X, ar->fw_features)) {
4985 ar->hw->wiphy->iface_combinations = ath10k_10x_if_comb;
4986 ar->hw->wiphy->n_iface_combinations =
4987 ARRAY_SIZE(ath10k_10x_if_comb);
4988 } else {
4989 ar->hw->wiphy->iface_combinations = ath10k_if_comb;
4990 ar->hw->wiphy->n_iface_combinations =
4991 ARRAY_SIZE(ath10k_if_comb);
Michal Kaziorcf850d12014-07-24 20:07:00 +03004992
4993 ar->hw->wiphy->interface_modes |= BIT(NL80211_IFTYPE_ADHOC);
Bartosz Markowskif2595092013-12-10 16:20:39 +01004994 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004995
Michal Kazior7c199992013-07-31 10:47:57 +02004996 ar->hw->netdev_features = NETIF_F_HW_CSUM;
4997
Janusz Dziedzic9702c682013-11-20 09:59:41 +02004998 if (config_enabled(CONFIG_ATH10K_DFS_CERTIFIED)) {
4999 /* Init ath dfs pattern detector */
5000 ar->ath_common.debug_mask = ATH_DBG_DFS;
5001 ar->dfs_detector = dfs_pattern_detector_init(&ar->ath_common,
5002 NL80211_DFS_UNSET);
5003
5004 if (!ar->dfs_detector)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005005 ath10k_warn(ar, "failed to initialise DFS pattern detector\n");
Janusz Dziedzic9702c682013-11-20 09:59:41 +02005006 }
5007
Kalle Valo5e3dd152013-06-12 20:52:10 +03005008 ret = ath_regd_init(&ar->ath_common.regulatory, ar->hw->wiphy,
5009 ath10k_reg_notifier);
5010 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005011 ath10k_err(ar, "failed to initialise regulatory: %i\n", ret);
Michal Kaziord6015b22013-07-22 14:13:30 +02005012 goto err_free;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005013 }
5014
5015 ret = ieee80211_register_hw(ar->hw);
5016 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005017 ath10k_err(ar, "failed to register ieee80211: %d\n", ret);
Michal Kaziord6015b22013-07-22 14:13:30 +02005018 goto err_free;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005019 }
5020
5021 if (!ath_is_world_regd(&ar->ath_common.regulatory)) {
5022 ret = regulatory_hint(ar->hw->wiphy,
5023 ar->ath_common.regulatory.alpha2);
5024 if (ret)
Michal Kaziord6015b22013-07-22 14:13:30 +02005025 goto err_unregister;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005026 }
5027
5028 return 0;
Michal Kaziord6015b22013-07-22 14:13:30 +02005029
5030err_unregister:
Kalle Valo5e3dd152013-06-12 20:52:10 +03005031 ieee80211_unregister_hw(ar->hw);
Michal Kaziord6015b22013-07-22 14:13:30 +02005032err_free:
5033 kfree(ar->mac.sbands[IEEE80211_BAND_2GHZ].channels);
5034 kfree(ar->mac.sbands[IEEE80211_BAND_5GHZ].channels);
5035
Kalle Valo5e3dd152013-06-12 20:52:10 +03005036 return ret;
5037}
5038
5039void ath10k_mac_unregister(struct ath10k *ar)
5040{
5041 ieee80211_unregister_hw(ar->hw);
5042
Janusz Dziedzic9702c682013-11-20 09:59:41 +02005043 if (config_enabled(CONFIG_ATH10K_DFS_CERTIFIED) && ar->dfs_detector)
5044 ar->dfs_detector->exit(ar->dfs_detector);
5045
Kalle Valo5e3dd152013-06-12 20:52:10 +03005046 kfree(ar->mac.sbands[IEEE80211_BAND_2GHZ].channels);
5047 kfree(ar->mac.sbands[IEEE80211_BAND_5GHZ].channels);
5048
5049 SET_IEEE80211_DEV(ar->hw, NULL);
5050}