blob: 4b69a373382b25f6dda8d770fc0028bda50d7a44 [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"
Michal Kaziord7579d12014-12-03 10:10:54 +020030#include "wmi.h"
Michal Kaziorb4aa5392015-03-31 10:26:24 +000031#include "wmi-tlv.h"
Michal Kaziord7579d12014-12-03 10:10:54 +020032#include "wmi-ops.h"
Janusz Dziedzic5fd3ac32015-03-23 17:32:53 +020033#include "wow.h"
Kalle Valo5e3dd152013-06-12 20:52:10 +030034
Michal Kaziordcc33092015-03-30 09:51:54 +030035/*********/
36/* Rates */
37/*********/
38
Michal Kaziordcc33092015-03-30 09:51:54 +030039static struct ieee80211_rate ath10k_rates[] = {
Michal Kazior5528e032015-03-30 09:51:56 +030040 { .bitrate = 10,
41 .hw_value = ATH10K_HW_RATE_CCK_LP_1M },
42 { .bitrate = 20,
43 .hw_value = ATH10K_HW_RATE_CCK_LP_2M,
44 .hw_value_short = ATH10K_HW_RATE_CCK_SP_2M,
45 .flags = IEEE80211_RATE_SHORT_PREAMBLE },
46 { .bitrate = 55,
47 .hw_value = ATH10K_HW_RATE_CCK_LP_5_5M,
48 .hw_value_short = ATH10K_HW_RATE_CCK_SP_5_5M,
49 .flags = IEEE80211_RATE_SHORT_PREAMBLE },
50 { .bitrate = 110,
51 .hw_value = ATH10K_HW_RATE_CCK_LP_11M,
52 .hw_value_short = ATH10K_HW_RATE_CCK_SP_11M,
53 .flags = IEEE80211_RATE_SHORT_PREAMBLE },
Michal Kazior5653b392015-03-30 09:51:54 +030054
Michal Kazioraf001482015-03-30 09:51:56 +030055 { .bitrate = 60, .hw_value = ATH10K_HW_RATE_OFDM_6M },
56 { .bitrate = 90, .hw_value = ATH10K_HW_RATE_OFDM_9M },
57 { .bitrate = 120, .hw_value = ATH10K_HW_RATE_OFDM_12M },
58 { .bitrate = 180, .hw_value = ATH10K_HW_RATE_OFDM_18M },
59 { .bitrate = 240, .hw_value = ATH10K_HW_RATE_OFDM_24M },
60 { .bitrate = 360, .hw_value = ATH10K_HW_RATE_OFDM_36M },
61 { .bitrate = 480, .hw_value = ATH10K_HW_RATE_OFDM_48M },
62 { .bitrate = 540, .hw_value = ATH10K_HW_RATE_OFDM_54M },
Michal Kaziordcc33092015-03-30 09:51:54 +030063};
64
Michal Kazior8d7aa6b2015-03-30 09:51:57 +030065#define ATH10K_MAC_FIRST_OFDM_RATE_IDX 4
66
67#define ath10k_a_rates (ath10k_rates + ATH10K_MAC_FIRST_OFDM_RATE_IDX)
68#define ath10k_a_rates_size (ARRAY_SIZE(ath10k_rates) - \
69 ATH10K_MAC_FIRST_OFDM_RATE_IDX)
Michal Kaziordcc33092015-03-30 09:51:54 +030070#define ath10k_g_rates (ath10k_rates + 0)
71#define ath10k_g_rates_size (ARRAY_SIZE(ath10k_rates))
72
Michal Kazior486017c2015-03-30 09:51:54 +030073static bool ath10k_mac_bitrate_is_cck(int bitrate)
74{
75 switch (bitrate) {
76 case 10:
77 case 20:
78 case 55:
79 case 110:
80 return true;
81 }
82
83 return false;
84}
85
86static u8 ath10k_mac_bitrate_to_rate(int bitrate)
87{
88 return DIV_ROUND_UP(bitrate, 5) |
89 (ath10k_mac_bitrate_is_cck(bitrate) ? BIT(7) : 0);
90}
91
Michal Kazior5528e032015-03-30 09:51:56 +030092u8 ath10k_mac_hw_rate_to_idx(const struct ieee80211_supported_band *sband,
Yanbo Li4b7f3532015-11-12 10:36:10 -080093 u8 hw_rate, bool cck)
Michal Kazior5528e032015-03-30 09:51:56 +030094{
95 const struct ieee80211_rate *rate;
96 int i;
97
98 for (i = 0; i < sband->n_bitrates; i++) {
99 rate = &sband->bitrates[i];
100
Yanbo Li4b7f3532015-11-12 10:36:10 -0800101 if (ath10k_mac_bitrate_is_cck(rate->bitrate) != cck)
102 continue;
103
Michal Kazior5528e032015-03-30 09:51:56 +0300104 if (rate->hw_value == hw_rate)
105 return i;
106 else if (rate->flags & IEEE80211_RATE_SHORT_PREAMBLE &&
107 rate->hw_value_short == hw_rate)
108 return i;
109 }
110
111 return 0;
112}
113
Michal Kazior01cebe12015-03-30 09:51:56 +0300114u8 ath10k_mac_bitrate_to_idx(const struct ieee80211_supported_band *sband,
115 u32 bitrate)
116{
117 int i;
118
119 for (i = 0; i < sband->n_bitrates; i++)
120 if (sband->bitrates[i].bitrate == bitrate)
121 return i;
122
123 return 0;
124}
125
Michal Kazior3ae54222015-03-31 10:49:20 +0000126static int ath10k_mac_get_max_vht_mcs_map(u16 mcs_map, int nss)
127{
128 switch ((mcs_map >> (2 * nss)) & 0x3) {
129 case IEEE80211_VHT_MCS_SUPPORT_0_7: return BIT(8) - 1;
130 case IEEE80211_VHT_MCS_SUPPORT_0_8: return BIT(9) - 1;
131 case IEEE80211_VHT_MCS_SUPPORT_0_9: return BIT(10) - 1;
132 }
133 return 0;
134}
135
Michal Kazior45c9abc2015-04-21 20:42:58 +0300136static u32
137ath10k_mac_max_ht_nss(const u8 ht_mcs_mask[IEEE80211_HT_MCS_MASK_LEN])
138{
139 int nss;
140
141 for (nss = IEEE80211_HT_MCS_MASK_LEN - 1; nss >= 0; nss--)
142 if (ht_mcs_mask[nss])
143 return nss + 1;
144
145 return 1;
146}
147
148static u32
149ath10k_mac_max_vht_nss(const u16 vht_mcs_mask[NL80211_VHT_NSS_MAX])
150{
151 int nss;
152
153 for (nss = NL80211_VHT_NSS_MAX - 1; nss >= 0; nss--)
154 if (vht_mcs_mask[nss])
155 return nss + 1;
156
157 return 1;
158}
Kalle Valo5e3dd152013-06-12 20:52:10 +0300159
160/**********/
161/* Crypto */
162/**********/
163
164static int ath10k_send_key(struct ath10k_vif *arvif,
165 struct ieee80211_key_conf *key,
166 enum set_key_cmd cmd,
Michal Kazior370e5672015-02-18 14:02:26 +0100167 const u8 *macaddr, u32 flags)
Kalle Valo5e3dd152013-06-12 20:52:10 +0300168{
Michal Kazior7aa7a722014-08-25 12:09:38 +0200169 struct ath10k *ar = arvif->ar;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300170 struct wmi_vdev_install_key_arg arg = {
171 .vdev_id = arvif->vdev_id,
172 .key_idx = key->keyidx,
173 .key_len = key->keylen,
174 .key_data = key->key,
Michal Kazior370e5672015-02-18 14:02:26 +0100175 .key_flags = flags,
Kalle Valo5e3dd152013-06-12 20:52:10 +0300176 .macaddr = macaddr,
177 };
178
Michal Kazior548db542013-07-05 16:15:15 +0300179 lockdep_assert_held(&arvif->ar->conf_mutex);
180
Kalle Valo5e3dd152013-06-12 20:52:10 +0300181 switch (key->cipher) {
182 case WLAN_CIPHER_SUITE_CCMP:
183 arg.key_cipher = WMI_CIPHER_AES_CCM;
Marek Kwaczynskie4e82e92015-01-24 12:14:53 +0200184 key->flags |= IEEE80211_KEY_FLAG_GENERATE_IV_MGMT;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300185 break;
186 case WLAN_CIPHER_SUITE_TKIP:
Kalle Valo5e3dd152013-06-12 20:52:10 +0300187 arg.key_cipher = WMI_CIPHER_TKIP;
188 arg.key_txmic_len = 8;
189 arg.key_rxmic_len = 8;
190 break;
191 case WLAN_CIPHER_SUITE_WEP40:
192 case WLAN_CIPHER_SUITE_WEP104:
193 arg.key_cipher = WMI_CIPHER_WEP;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300194 break;
Johannes Berg3cb10942015-01-22 21:38:45 +0100195 case WLAN_CIPHER_SUITE_AES_CMAC:
Bartosz Markowskid7131c02015-03-10 14:32:19 +0100196 WARN_ON(1);
197 return -EINVAL;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300198 default:
Michal Kazior7aa7a722014-08-25 12:09:38 +0200199 ath10k_warn(ar, "cipher %d is not supported\n", key->cipher);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300200 return -EOPNOTSUPP;
201 }
202
Kalle Valob9e284e2015-10-05 17:56:35 +0300203 if (test_bit(ATH10K_FLAG_RAW_MODE, &ar->dev_flags))
David Liuccec9032015-07-24 20:25:32 +0300204 key->flags |= IEEE80211_KEY_FLAG_GENERATE_IV;
David Liuccec9032015-07-24 20:25:32 +0300205
Kalle Valo5e3dd152013-06-12 20:52:10 +0300206 if (cmd == DISABLE_KEY) {
207 arg.key_cipher = WMI_CIPHER_NONE;
208 arg.key_data = NULL;
209 }
210
211 return ath10k_wmi_vdev_install_key(arvif->ar, &arg);
212}
213
214static int ath10k_install_key(struct ath10k_vif *arvif,
215 struct ieee80211_key_conf *key,
216 enum set_key_cmd cmd,
Michal Kazior370e5672015-02-18 14:02:26 +0100217 const u8 *macaddr, u32 flags)
Kalle Valo5e3dd152013-06-12 20:52:10 +0300218{
219 struct ath10k *ar = arvif->ar;
220 int ret;
Nicholas Mc Guire8e9904f52015-03-30 15:39:19 +0300221 unsigned long time_left;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300222
Michal Kazior548db542013-07-05 16:15:15 +0300223 lockdep_assert_held(&ar->conf_mutex);
224
Wolfram Sang16735d02013-11-14 14:32:02 -0800225 reinit_completion(&ar->install_key_done);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300226
David Liuccec9032015-07-24 20:25:32 +0300227 if (arvif->nohwcrypt)
228 return 1;
229
Michal Kazior370e5672015-02-18 14:02:26 +0100230 ret = ath10k_send_key(arvif, key, cmd, macaddr, flags);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300231 if (ret)
232 return ret;
233
Nicholas Mc Guire8e9904f52015-03-30 15:39:19 +0300234 time_left = wait_for_completion_timeout(&ar->install_key_done, 3 * HZ);
235 if (time_left == 0)
Kalle Valo5e3dd152013-06-12 20:52:10 +0300236 return -ETIMEDOUT;
237
238 return 0;
239}
240
241static int ath10k_install_peer_wep_keys(struct ath10k_vif *arvif,
242 const u8 *addr)
243{
244 struct ath10k *ar = arvif->ar;
245 struct ath10k_peer *peer;
246 int ret;
247 int i;
Michal Kazior370e5672015-02-18 14:02:26 +0100248 u32 flags;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300249
250 lockdep_assert_held(&ar->conf_mutex);
251
Michal Kazior8674d902015-08-13 14:10:46 +0200252 if (WARN_ON(arvif->vif->type != NL80211_IFTYPE_AP &&
Peter Oh7c97b722015-12-03 09:50:55 -0800253 arvif->vif->type != NL80211_IFTYPE_ADHOC &&
254 arvif->vif->type != NL80211_IFTYPE_MESH_POINT))
Michal Kazior8674d902015-08-13 14:10:46 +0200255 return -EINVAL;
256
Kalle Valo5e3dd152013-06-12 20:52:10 +0300257 spin_lock_bh(&ar->data_lock);
258 peer = ath10k_peer_find(ar, arvif->vdev_id, addr);
259 spin_unlock_bh(&ar->data_lock);
260
261 if (!peer)
262 return -ENOENT;
263
264 for (i = 0; i < ARRAY_SIZE(arvif->wep_keys); i++) {
265 if (arvif->wep_keys[i] == NULL)
266 continue;
Michal Kazior370e5672015-02-18 14:02:26 +0100267
Michal Kazior8674d902015-08-13 14:10:46 +0200268 switch (arvif->vif->type) {
269 case NL80211_IFTYPE_AP:
270 flags = WMI_KEY_PAIRWISE;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300271
Michal Kazior8674d902015-08-13 14:10:46 +0200272 if (arvif->def_wep_key_idx == i)
273 flags |= WMI_KEY_TX_USAGE;
Michal Kaziorce90b272015-04-10 13:23:21 +0000274
Michal Kazior8674d902015-08-13 14:10:46 +0200275 ret = ath10k_install_key(arvif, arvif->wep_keys[i],
276 SET_KEY, addr, flags);
277 if (ret < 0)
278 return ret;
279 break;
280 case NL80211_IFTYPE_ADHOC:
281 ret = ath10k_install_key(arvif, arvif->wep_keys[i],
282 SET_KEY, addr,
283 WMI_KEY_PAIRWISE);
284 if (ret < 0)
285 return ret;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300286
Michal Kazior8674d902015-08-13 14:10:46 +0200287 ret = ath10k_install_key(arvif, arvif->wep_keys[i],
288 SET_KEY, addr, WMI_KEY_GROUP);
289 if (ret < 0)
290 return ret;
291 break;
292 default:
293 WARN_ON(1);
294 return -EINVAL;
295 }
Kalle Valo5e3dd152013-06-12 20:52:10 +0300296
Sujith Manoharanae167132014-11-25 11:46:59 +0530297 spin_lock_bh(&ar->data_lock);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300298 peer->keys[i] = arvif->wep_keys[i];
Sujith Manoharanae167132014-11-25 11:46:59 +0530299 spin_unlock_bh(&ar->data_lock);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300300 }
301
Michal Kaziorce90b272015-04-10 13:23:21 +0000302 /* In some cases (notably with static WEP IBSS with multiple keys)
303 * multicast Tx becomes broken. Both pairwise and groupwise keys are
304 * installed already. Using WMI_KEY_TX_USAGE in different combinations
305 * didn't seem help. Using def_keyid vdev parameter seems to be
306 * effective so use that.
307 *
308 * FIXME: Revisit. Perhaps this can be done in a less hacky way.
309 */
Michal Kazior8674d902015-08-13 14:10:46 +0200310 if (arvif->vif->type != NL80211_IFTYPE_ADHOC)
311 return 0;
312
Michal Kaziorce90b272015-04-10 13:23:21 +0000313 if (arvif->def_wep_key_idx == -1)
314 return 0;
315
316 ret = ath10k_wmi_vdev_set_param(arvif->ar,
317 arvif->vdev_id,
318 arvif->ar->wmi.vdev_param->def_keyid,
319 arvif->def_wep_key_idx);
320 if (ret) {
321 ath10k_warn(ar, "failed to re-set def wpa key idxon vdev %i: %d\n",
322 arvif->vdev_id, ret);
323 return ret;
324 }
325
Kalle Valo5e3dd152013-06-12 20:52:10 +0300326 return 0;
327}
328
329static int ath10k_clear_peer_keys(struct ath10k_vif *arvif,
330 const u8 *addr)
331{
332 struct ath10k *ar = arvif->ar;
333 struct ath10k_peer *peer;
334 int first_errno = 0;
335 int ret;
336 int i;
Michal Kazior370e5672015-02-18 14:02:26 +0100337 u32 flags = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300338
339 lockdep_assert_held(&ar->conf_mutex);
340
341 spin_lock_bh(&ar->data_lock);
342 peer = ath10k_peer_find(ar, arvif->vdev_id, addr);
343 spin_unlock_bh(&ar->data_lock);
344
345 if (!peer)
346 return -ENOENT;
347
348 for (i = 0; i < ARRAY_SIZE(peer->keys); i++) {
349 if (peer->keys[i] == NULL)
350 continue;
351
SenthilKumar Jegadeesan627613f2015-01-29 13:50:38 +0200352 /* key flags are not required to delete the key */
Kalle Valo5e3dd152013-06-12 20:52:10 +0300353 ret = ath10k_install_key(arvif, peer->keys[i],
Michal Kazior370e5672015-02-18 14:02:26 +0100354 DISABLE_KEY, addr, flags);
David Liuccec9032015-07-24 20:25:32 +0300355 if (ret < 0 && first_errno == 0)
Kalle Valo5e3dd152013-06-12 20:52:10 +0300356 first_errno = ret;
357
David Liuccec9032015-07-24 20:25:32 +0300358 if (ret < 0)
Michal Kazior7aa7a722014-08-25 12:09:38 +0200359 ath10k_warn(ar, "failed to remove peer wep key %d: %d\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +0300360 i, ret);
361
Sujith Manoharanae167132014-11-25 11:46:59 +0530362 spin_lock_bh(&ar->data_lock);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300363 peer->keys[i] = NULL;
Sujith Manoharanae167132014-11-25 11:46:59 +0530364 spin_unlock_bh(&ar->data_lock);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300365 }
366
367 return first_errno;
368}
369
Sujith Manoharan504f6cd2014-11-25 11:46:58 +0530370bool ath10k_mac_is_peer_wep_key_set(struct ath10k *ar, const u8 *addr,
371 u8 keyidx)
372{
373 struct ath10k_peer *peer;
374 int i;
375
376 lockdep_assert_held(&ar->data_lock);
377
378 /* We don't know which vdev this peer belongs to,
379 * since WMI doesn't give us that information.
380 *
381 * FIXME: multi-bss needs to be handled.
382 */
383 peer = ath10k_peer_find(ar, 0, addr);
384 if (!peer)
385 return false;
386
387 for (i = 0; i < ARRAY_SIZE(peer->keys); i++) {
388 if (peer->keys[i] && peer->keys[i]->keyidx == keyidx)
389 return true;
390 }
391
392 return false;
393}
394
Kalle Valo5e3dd152013-06-12 20:52:10 +0300395static int ath10k_clear_vdev_key(struct ath10k_vif *arvif,
396 struct ieee80211_key_conf *key)
397{
398 struct ath10k *ar = arvif->ar;
399 struct ath10k_peer *peer;
400 u8 addr[ETH_ALEN];
401 int first_errno = 0;
402 int ret;
403 int i;
Michal Kazior370e5672015-02-18 14:02:26 +0100404 u32 flags = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300405
406 lockdep_assert_held(&ar->conf_mutex);
407
408 for (;;) {
409 /* since ath10k_install_key we can't hold data_lock all the
410 * time, so we try to remove the keys incrementally */
411 spin_lock_bh(&ar->data_lock);
412 i = 0;
413 list_for_each_entry(peer, &ar->peers, list) {
414 for (i = 0; i < ARRAY_SIZE(peer->keys); i++) {
415 if (peer->keys[i] == key) {
Kalle Valob25f32c2014-09-14 12:50:49 +0300416 ether_addr_copy(addr, peer->addr);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300417 peer->keys[i] = NULL;
418 break;
419 }
420 }
421
422 if (i < ARRAY_SIZE(peer->keys))
423 break;
424 }
425 spin_unlock_bh(&ar->data_lock);
426
427 if (i == ARRAY_SIZE(peer->keys))
428 break;
SenthilKumar Jegadeesan627613f2015-01-29 13:50:38 +0200429 /* key flags are not required to delete the key */
Michal Kazior370e5672015-02-18 14:02:26 +0100430 ret = ath10k_install_key(arvif, key, DISABLE_KEY, addr, flags);
David Liuccec9032015-07-24 20:25:32 +0300431 if (ret < 0 && first_errno == 0)
Kalle Valo5e3dd152013-06-12 20:52:10 +0300432 first_errno = ret;
433
434 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +0200435 ath10k_warn(ar, "failed to remove key for %pM: %d\n",
Kalle Valobe6546f2014-03-25 14:18:51 +0200436 addr, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300437 }
438
439 return first_errno;
440}
441
Michal Kaziorad325cb2015-02-18 14:02:27 +0100442static int ath10k_mac_vif_update_wep_key(struct ath10k_vif *arvif,
443 struct ieee80211_key_conf *key)
444{
445 struct ath10k *ar = arvif->ar;
446 struct ath10k_peer *peer;
447 int ret;
448
449 lockdep_assert_held(&ar->conf_mutex);
450
451 list_for_each_entry(peer, &ar->peers, list) {
452 if (!memcmp(peer->addr, arvif->vif->addr, ETH_ALEN))
453 continue;
454
455 if (!memcmp(peer->addr, arvif->bssid, ETH_ALEN))
456 continue;
457
458 if (peer->keys[key->keyidx] == key)
459 continue;
460
461 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vif vdev %i update key %i needs update\n",
462 arvif->vdev_id, key->keyidx);
463
464 ret = ath10k_install_peer_wep_keys(arvif, peer->addr);
465 if (ret) {
466 ath10k_warn(ar, "failed to update wep keys on vdev %i for peer %pM: %d\n",
467 arvif->vdev_id, peer->addr, ret);
468 return ret;
469 }
470 }
471
472 return 0;
473}
474
Kalle Valo5e3dd152013-06-12 20:52:10 +0300475/*********************/
476/* General utilities */
477/*********************/
478
479static inline enum wmi_phy_mode
480chan_to_phymode(const struct cfg80211_chan_def *chandef)
481{
482 enum wmi_phy_mode phymode = MODE_UNKNOWN;
483
484 switch (chandef->chan->band) {
485 case IEEE80211_BAND_2GHZ:
486 switch (chandef->width) {
487 case NL80211_CHAN_WIDTH_20_NOHT:
Peter Oh6faab122014-12-18 10:13:00 -0800488 if (chandef->chan->flags & IEEE80211_CHAN_NO_OFDM)
489 phymode = MODE_11B;
490 else
491 phymode = MODE_11G;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300492 break;
493 case NL80211_CHAN_WIDTH_20:
494 phymode = MODE_11NG_HT20;
495 break;
496 case NL80211_CHAN_WIDTH_40:
497 phymode = MODE_11NG_HT40;
498 break;
John W. Linville0f817ed2013-06-27 13:50:09 -0400499 case NL80211_CHAN_WIDTH_5:
500 case NL80211_CHAN_WIDTH_10:
Kalle Valo5e3dd152013-06-12 20:52:10 +0300501 case NL80211_CHAN_WIDTH_80:
502 case NL80211_CHAN_WIDTH_80P80:
503 case NL80211_CHAN_WIDTH_160:
504 phymode = MODE_UNKNOWN;
505 break;
506 }
507 break;
508 case IEEE80211_BAND_5GHZ:
509 switch (chandef->width) {
510 case NL80211_CHAN_WIDTH_20_NOHT:
511 phymode = MODE_11A;
512 break;
513 case NL80211_CHAN_WIDTH_20:
514 phymode = MODE_11NA_HT20;
515 break;
516 case NL80211_CHAN_WIDTH_40:
517 phymode = MODE_11NA_HT40;
518 break;
519 case NL80211_CHAN_WIDTH_80:
520 phymode = MODE_11AC_VHT80;
521 break;
John W. Linville0f817ed2013-06-27 13:50:09 -0400522 case NL80211_CHAN_WIDTH_5:
523 case NL80211_CHAN_WIDTH_10:
Kalle Valo5e3dd152013-06-12 20:52:10 +0300524 case NL80211_CHAN_WIDTH_80P80:
525 case NL80211_CHAN_WIDTH_160:
526 phymode = MODE_UNKNOWN;
527 break;
528 }
529 break;
530 default:
531 break;
532 }
533
534 WARN_ON(phymode == MODE_UNKNOWN);
535 return phymode;
536}
537
538static u8 ath10k_parse_mpdudensity(u8 mpdudensity)
539{
540/*
541 * 802.11n D2.0 defined values for "Minimum MPDU Start Spacing":
542 * 0 for no restriction
543 * 1 for 1/4 us
544 * 2 for 1/2 us
545 * 3 for 1 us
546 * 4 for 2 us
547 * 5 for 4 us
548 * 6 for 8 us
549 * 7 for 16 us
550 */
551 switch (mpdudensity) {
552 case 0:
553 return 0;
554 case 1:
555 case 2:
556 case 3:
557 /* Our lower layer calculations limit our precision to
558 1 microsecond */
559 return 1;
560 case 4:
561 return 2;
562 case 5:
563 return 4;
564 case 6:
565 return 8;
566 case 7:
567 return 16;
568 default:
569 return 0;
570 }
571}
572
Michal Kazior500ff9f2015-03-31 10:26:21 +0000573int ath10k_mac_vif_chan(struct ieee80211_vif *vif,
574 struct cfg80211_chan_def *def)
575{
576 struct ieee80211_chanctx_conf *conf;
577
578 rcu_read_lock();
579 conf = rcu_dereference(vif->chanctx_conf);
580 if (!conf) {
581 rcu_read_unlock();
582 return -ENOENT;
583 }
584
585 *def = conf->def;
586 rcu_read_unlock();
587
588 return 0;
589}
590
591static void ath10k_mac_num_chanctxs_iter(struct ieee80211_hw *hw,
592 struct ieee80211_chanctx_conf *conf,
593 void *data)
594{
595 int *num = data;
596
597 (*num)++;
598}
599
600static int ath10k_mac_num_chanctxs(struct ath10k *ar)
601{
602 int num = 0;
603
604 ieee80211_iter_chan_contexts_atomic(ar->hw,
605 ath10k_mac_num_chanctxs_iter,
606 &num);
607
608 return num;
609}
610
611static void
612ath10k_mac_get_any_chandef_iter(struct ieee80211_hw *hw,
613 struct ieee80211_chanctx_conf *conf,
614 void *data)
615{
616 struct cfg80211_chan_def **def = data;
617
618 *def = &conf->def;
619}
620
Michal Kazior69427262016-03-06 16:14:30 +0200621static int ath10k_peer_create(struct ath10k *ar,
622 struct ieee80211_vif *vif,
623 struct ieee80211_sta *sta,
624 u32 vdev_id,
625 const u8 *addr,
Marek Puzyniak7390ed32015-03-30 09:51:52 +0300626 enum wmi_peer_type peer_type)
Kalle Valo5e3dd152013-06-12 20:52:10 +0300627{
Michal Kaziore04cafb2015-08-05 12:15:24 +0200628 struct ath10k_vif *arvif;
Michal Kazior69427262016-03-06 16:14:30 +0200629 struct ath10k_peer *peer;
Michal Kaziore04cafb2015-08-05 12:15:24 +0200630 int num_peers = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300631 int ret;
632
633 lockdep_assert_held(&ar->conf_mutex);
634
Michal Kaziore04cafb2015-08-05 12:15:24 +0200635 num_peers = ar->num_peers;
636
637 /* Each vdev consumes a peer entry as well */
638 list_for_each_entry(arvif, &ar->arvifs, list)
639 num_peers++;
640
641 if (num_peers >= ar->max_num_peers)
Michal Kaziorcfd10612014-11-25 15:16:05 +0100642 return -ENOBUFS;
643
Marek Puzyniak7390ed32015-03-30 09:51:52 +0300644 ret = ath10k_wmi_peer_create(ar, vdev_id, addr, peer_type);
Ben Greear479398b2013-11-04 09:19:34 -0800645 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200646 ath10k_warn(ar, "failed to create wmi peer %pM on vdev %i: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +0200647 addr, vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300648 return ret;
Ben Greear479398b2013-11-04 09:19:34 -0800649 }
Kalle Valo5e3dd152013-06-12 20:52:10 +0300650
651 ret = ath10k_wait_for_peer_created(ar, vdev_id, addr);
Ben Greear479398b2013-11-04 09:19:34 -0800652 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200653 ath10k_warn(ar, "failed to wait for created wmi peer %pM on vdev %i: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +0200654 addr, vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300655 return ret;
Ben Greear479398b2013-11-04 09:19:34 -0800656 }
Michal Kazior292a7532014-11-25 15:16:04 +0100657
Michal Kazior69427262016-03-06 16:14:30 +0200658 spin_lock_bh(&ar->data_lock);
659
660 peer = ath10k_peer_find(ar, vdev_id, addr);
661 if (!peer) {
662 ath10k_warn(ar, "failed to find peer %pM on vdev %i after creation\n",
663 addr, vdev_id);
664 ath10k_wmi_peer_delete(ar, vdev_id, addr);
665 spin_unlock_bh(&ar->data_lock);
666 return -ENOENT;
667 }
668
669 peer->vif = vif;
670 peer->sta = sta;
671
672 spin_unlock_bh(&ar->data_lock);
673
Bartosz Markowski0e759f32014-01-02 14:38:33 +0100674 ar->num_peers++;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300675
676 return 0;
677}
678
Kalle Valo5a13e762014-01-20 11:01:46 +0200679static int ath10k_mac_set_kickout(struct ath10k_vif *arvif)
680{
681 struct ath10k *ar = arvif->ar;
682 u32 param;
683 int ret;
684
685 param = ar->wmi.pdev_param->sta_kickout_th;
686 ret = ath10k_wmi_pdev_set_param(ar, param,
687 ATH10K_KICKOUT_THRESHOLD);
688 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200689 ath10k_warn(ar, "failed to set kickout threshold on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200690 arvif->vdev_id, ret);
Kalle Valo5a13e762014-01-20 11:01:46 +0200691 return ret;
692 }
693
694 param = ar->wmi.vdev_param->ap_keepalive_min_idle_inactive_time_secs;
695 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, param,
696 ATH10K_KEEPALIVE_MIN_IDLE);
697 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200698 ath10k_warn(ar, "failed to set keepalive minimum idle time on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200699 arvif->vdev_id, ret);
Kalle Valo5a13e762014-01-20 11:01:46 +0200700 return ret;
701 }
702
703 param = ar->wmi.vdev_param->ap_keepalive_max_idle_inactive_time_secs;
704 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, param,
705 ATH10K_KEEPALIVE_MAX_IDLE);
706 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200707 ath10k_warn(ar, "failed to set keepalive maximum idle time on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200708 arvif->vdev_id, ret);
Kalle Valo5a13e762014-01-20 11:01:46 +0200709 return ret;
710 }
711
712 param = ar->wmi.vdev_param->ap_keepalive_max_unresponsive_time_secs;
713 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, param,
714 ATH10K_KEEPALIVE_MAX_UNRESPONSIVE);
715 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200716 ath10k_warn(ar, "failed to set keepalive maximum unresponsive time on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200717 arvif->vdev_id, ret);
Kalle Valo5a13e762014-01-20 11:01:46 +0200718 return ret;
719 }
720
721 return 0;
722}
723
Vivek Natarajanacab6402014-11-26 09:06:12 +0200724static int ath10k_mac_set_rts(struct ath10k_vif *arvif, u32 value)
Michal Kazior424121c2013-07-22 14:13:31 +0200725{
Bartosz Markowski6d1506e2013-09-26 17:47:15 +0200726 struct ath10k *ar = arvif->ar;
727 u32 vdev_param;
728
Bartosz Markowski6d1506e2013-09-26 17:47:15 +0200729 vdev_param = ar->wmi.vdev_param->rts_threshold;
730 return ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param, value);
Michal Kazior424121c2013-07-22 14:13:31 +0200731}
732
Kalle Valo5e3dd152013-06-12 20:52:10 +0300733static int ath10k_peer_delete(struct ath10k *ar, u32 vdev_id, const u8 *addr)
734{
735 int ret;
736
737 lockdep_assert_held(&ar->conf_mutex);
738
739 ret = ath10k_wmi_peer_delete(ar, vdev_id, addr);
740 if (ret)
741 return ret;
742
743 ret = ath10k_wait_for_peer_deleted(ar, vdev_id, addr);
744 if (ret)
745 return ret;
746
Bartosz Markowski0e759f32014-01-02 14:38:33 +0100747 ar->num_peers--;
Bartosz Markowski0e759f32014-01-02 14:38:33 +0100748
Kalle Valo5e3dd152013-06-12 20:52:10 +0300749 return 0;
750}
751
752static void ath10k_peer_cleanup(struct ath10k *ar, u32 vdev_id)
753{
754 struct ath10k_peer *peer, *tmp;
Michal Kazior69427262016-03-06 16:14:30 +0200755 int peer_id;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300756
757 lockdep_assert_held(&ar->conf_mutex);
758
759 spin_lock_bh(&ar->data_lock);
760 list_for_each_entry_safe(peer, tmp, &ar->peers, list) {
761 if (peer->vdev_id != vdev_id)
762 continue;
763
Michal Kazior7aa7a722014-08-25 12:09:38 +0200764 ath10k_warn(ar, "removing stale peer %pM from vdev_id %d\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +0300765 peer->addr, vdev_id);
766
Michal Kazior69427262016-03-06 16:14:30 +0200767 for_each_set_bit(peer_id, peer->peer_ids,
768 ATH10K_MAX_NUM_PEER_IDS) {
769 ar->peer_map[peer_id] = NULL;
770 }
771
Kalle Valo5e3dd152013-06-12 20:52:10 +0300772 list_del(&peer->list);
773 kfree(peer);
Bartosz Markowski0e759f32014-01-02 14:38:33 +0100774 ar->num_peers--;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300775 }
776 spin_unlock_bh(&ar->data_lock);
777}
778
Michal Kaziora96d7742013-07-16 09:38:56 +0200779static void ath10k_peer_cleanup_all(struct ath10k *ar)
780{
781 struct ath10k_peer *peer, *tmp;
782
783 lockdep_assert_held(&ar->conf_mutex);
784
785 spin_lock_bh(&ar->data_lock);
786 list_for_each_entry_safe(peer, tmp, &ar->peers, list) {
787 list_del(&peer->list);
788 kfree(peer);
789 }
790 spin_unlock_bh(&ar->data_lock);
Michal Kazior292a7532014-11-25 15:16:04 +0100791
792 ar->num_peers = 0;
Michal Kaziorcfd10612014-11-25 15:16:05 +0100793 ar->num_stations = 0;
Michal Kaziora96d7742013-07-16 09:38:56 +0200794}
795
Marek Puzyniak75d85fd2015-03-30 09:51:53 +0300796static int ath10k_mac_tdls_peer_update(struct ath10k *ar, u32 vdev_id,
797 struct ieee80211_sta *sta,
798 enum wmi_tdls_peer_state state)
799{
800 int ret;
801 struct wmi_tdls_peer_update_cmd_arg arg = {};
802 struct wmi_tdls_peer_capab_arg cap = {};
803 struct wmi_channel_arg chan_arg = {};
804
805 lockdep_assert_held(&ar->conf_mutex);
806
807 arg.vdev_id = vdev_id;
808 arg.peer_state = state;
809 ether_addr_copy(arg.addr, sta->addr);
810
811 cap.peer_max_sp = sta->max_sp;
812 cap.peer_uapsd_queues = sta->uapsd_queues;
813
814 if (state == WMI_TDLS_PEER_STATE_CONNECTED &&
815 !sta->tdls_initiator)
816 cap.is_peer_responder = 1;
817
818 ret = ath10k_wmi_tdls_peer_update(ar, &arg, &cap, &chan_arg);
819 if (ret) {
820 ath10k_warn(ar, "failed to update tdls peer %pM on vdev %i: %i\n",
821 arg.addr, vdev_id, ret);
822 return ret;
823 }
824
825 return 0;
826}
827
Kalle Valo5e3dd152013-06-12 20:52:10 +0300828/************************/
829/* Interface management */
830/************************/
831
Michal Kazior64badcb2014-09-18 11:18:02 +0300832void ath10k_mac_vif_beacon_free(struct ath10k_vif *arvif)
833{
834 struct ath10k *ar = arvif->ar;
835
836 lockdep_assert_held(&ar->data_lock);
837
838 if (!arvif->beacon)
839 return;
840
841 if (!arvif->beacon_buf)
842 dma_unmap_single(ar->dev, ATH10K_SKB_CB(arvif->beacon)->paddr,
843 arvif->beacon->len, DMA_TO_DEVICE);
844
Michal Kazioraf213192015-01-29 14:29:52 +0200845 if (WARN_ON(arvif->beacon_state != ATH10K_BEACON_SCHEDULED &&
846 arvif->beacon_state != ATH10K_BEACON_SENT))
847 return;
848
Michal Kazior64badcb2014-09-18 11:18:02 +0300849 dev_kfree_skb_any(arvif->beacon);
850
851 arvif->beacon = NULL;
Michal Kazioraf213192015-01-29 14:29:52 +0200852 arvif->beacon_state = ATH10K_BEACON_SCHEDULED;
Michal Kazior64badcb2014-09-18 11:18:02 +0300853}
854
855static void ath10k_mac_vif_beacon_cleanup(struct ath10k_vif *arvif)
856{
857 struct ath10k *ar = arvif->ar;
858
859 lockdep_assert_held(&ar->data_lock);
860
861 ath10k_mac_vif_beacon_free(arvif);
862
863 if (arvif->beacon_buf) {
864 dma_free_coherent(ar->dev, IEEE80211_MAX_FRAME_LEN,
865 arvif->beacon_buf, arvif->beacon_paddr);
866 arvif->beacon_buf = NULL;
867 }
868}
869
Kalle Valo5e3dd152013-06-12 20:52:10 +0300870static inline int ath10k_vdev_setup_sync(struct ath10k *ar)
871{
Nicholas Mc Guire8e9904f52015-03-30 15:39:19 +0300872 unsigned long time_left;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300873
Michal Kazior548db542013-07-05 16:15:15 +0300874 lockdep_assert_held(&ar->conf_mutex);
875
Michal Kazior7962b0d2014-10-28 10:34:38 +0100876 if (test_bit(ATH10K_FLAG_CRASH_FLUSH, &ar->dev_flags))
877 return -ESHUTDOWN;
878
Nicholas Mc Guire8e9904f52015-03-30 15:39:19 +0300879 time_left = wait_for_completion_timeout(&ar->vdev_setup_done,
880 ATH10K_VDEV_SETUP_TIMEOUT_HZ);
881 if (time_left == 0)
Kalle Valo5e3dd152013-06-12 20:52:10 +0300882 return -ETIMEDOUT;
883
884 return 0;
885}
886
Michal Kazior1bbc0972014-04-08 09:45:47 +0300887static int ath10k_monitor_vdev_start(struct ath10k *ar, int vdev_id)
Kalle Valo5e3dd152013-06-12 20:52:10 +0300888{
Michal Kazior500ff9f2015-03-31 10:26:21 +0000889 struct cfg80211_chan_def *chandef = NULL;
Maninder Singh19be9e92015-07-16 09:25:33 +0530890 struct ieee80211_channel *channel = NULL;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300891 struct wmi_vdev_start_request_arg arg = {};
Kalle Valo5e3dd152013-06-12 20:52:10 +0300892 int ret = 0;
893
894 lockdep_assert_held(&ar->conf_mutex);
895
Michal Kazior500ff9f2015-03-31 10:26:21 +0000896 ieee80211_iter_chan_contexts_atomic(ar->hw,
897 ath10k_mac_get_any_chandef_iter,
898 &chandef);
899 if (WARN_ON_ONCE(!chandef))
900 return -ENOENT;
901
902 channel = chandef->chan;
903
Kalle Valo5e3dd152013-06-12 20:52:10 +0300904 arg.vdev_id = vdev_id;
905 arg.channel.freq = channel->center_freq;
Michal Kaziorc930f742014-01-23 11:38:25 +0100906 arg.channel.band_center_freq1 = chandef->center_freq1;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300907
908 /* TODO setup this dynamically, what in case we
909 don't have any vifs? */
Michal Kaziorc930f742014-01-23 11:38:25 +0100910 arg.channel.mode = chan_to_phymode(chandef);
Marek Puzyniake8a50f82013-11-20 09:59:47 +0200911 arg.channel.chan_radar =
912 !!(channel->flags & IEEE80211_CHAN_RADAR);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300913
Michal Kazior89c5c842013-10-23 04:02:13 -0700914 arg.channel.min_power = 0;
Michal Kazior02256932013-10-23 04:02:14 -0700915 arg.channel.max_power = channel->max_power * 2;
916 arg.channel.max_reg_power = channel->max_reg_power * 2;
917 arg.channel.max_antenna_gain = channel->max_antenna_gain * 2;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300918
Michal Kazior7962b0d2014-10-28 10:34:38 +0100919 reinit_completion(&ar->vdev_setup_done);
920
Kalle Valo5e3dd152013-06-12 20:52:10 +0300921 ret = ath10k_wmi_vdev_start(ar, &arg);
922 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200923 ath10k_warn(ar, "failed to request monitor vdev %i start: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200924 vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300925 return ret;
926 }
927
928 ret = ath10k_vdev_setup_sync(ar);
929 if (ret) {
Ben Greear60028a82015-02-15 16:50:39 +0200930 ath10k_warn(ar, "failed to synchronize setup for monitor vdev %i start: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200931 vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300932 return ret;
933 }
934
935 ret = ath10k_wmi_vdev_up(ar, vdev_id, 0, ar->mac_addr);
936 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200937 ath10k_warn(ar, "failed to put up monitor vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200938 vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300939 goto vdev_stop;
940 }
941
942 ar->monitor_vdev_id = vdev_id;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300943
Michal Kazior7aa7a722014-08-25 12:09:38 +0200944 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac monitor vdev %i started\n",
Michal Kazior1bbc0972014-04-08 09:45:47 +0300945 ar->monitor_vdev_id);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300946 return 0;
947
948vdev_stop:
949 ret = ath10k_wmi_vdev_stop(ar, ar->monitor_vdev_id);
950 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +0200951 ath10k_warn(ar, "failed to stop monitor vdev %i after start failure: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200952 ar->monitor_vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300953
954 return ret;
955}
956
Michal Kazior1bbc0972014-04-08 09:45:47 +0300957static int ath10k_monitor_vdev_stop(struct ath10k *ar)
Kalle Valo5e3dd152013-06-12 20:52:10 +0300958{
959 int ret = 0;
960
961 lockdep_assert_held(&ar->conf_mutex);
962
Marek Puzyniak52fa0192013-09-24 14:06:24 +0200963 ret = ath10k_wmi_vdev_down(ar, ar->monitor_vdev_id);
964 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +0200965 ath10k_warn(ar, "failed to put down monitor vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200966 ar->monitor_vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300967
Michal Kazior7962b0d2014-10-28 10:34:38 +0100968 reinit_completion(&ar->vdev_setup_done);
969
Kalle Valo5e3dd152013-06-12 20:52:10 +0300970 ret = ath10k_wmi_vdev_stop(ar, ar->monitor_vdev_id);
971 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +0200972 ath10k_warn(ar, "failed to to request monitor vdev %i stop: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200973 ar->monitor_vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300974
975 ret = ath10k_vdev_setup_sync(ar);
976 if (ret)
Ben Greear60028a82015-02-15 16:50:39 +0200977 ath10k_warn(ar, "failed to synchronize monitor vdev %i stop: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200978 ar->monitor_vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300979
Michal Kazior7aa7a722014-08-25 12:09:38 +0200980 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac monitor vdev %i stopped\n",
Michal Kazior1bbc0972014-04-08 09:45:47 +0300981 ar->monitor_vdev_id);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300982 return ret;
983}
984
Michal Kazior1bbc0972014-04-08 09:45:47 +0300985static int ath10k_monitor_vdev_create(struct ath10k *ar)
Kalle Valo5e3dd152013-06-12 20:52:10 +0300986{
987 int bit, ret = 0;
988
989 lockdep_assert_held(&ar->conf_mutex);
990
Ben Greeara9aefb32014-08-12 11:02:19 +0300991 if (ar->free_vdev_map == 0) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200992 ath10k_warn(ar, "failed to find free vdev id for monitor vdev\n");
Kalle Valo5e3dd152013-06-12 20:52:10 +0300993 return -ENOMEM;
994 }
995
Ben Greear16c11172014-09-23 14:17:16 -0700996 bit = __ffs64(ar->free_vdev_map);
Ben Greeara9aefb32014-08-12 11:02:19 +0300997
Ben Greear16c11172014-09-23 14:17:16 -0700998 ar->monitor_vdev_id = bit;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300999
1000 ret = ath10k_wmi_vdev_create(ar, ar->monitor_vdev_id,
1001 WMI_VDEV_TYPE_MONITOR,
1002 0, ar->mac_addr);
1003 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001004 ath10k_warn(ar, "failed to request monitor vdev %i creation: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02001005 ar->monitor_vdev_id, ret);
Ben Greeara9aefb32014-08-12 11:02:19 +03001006 return ret;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001007 }
1008
Ben Greear16c11172014-09-23 14:17:16 -07001009 ar->free_vdev_map &= ~(1LL << ar->monitor_vdev_id);
Michal Kazior7aa7a722014-08-25 12:09:38 +02001010 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac monitor vdev %d created\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03001011 ar->monitor_vdev_id);
1012
Kalle Valo5e3dd152013-06-12 20:52:10 +03001013 return 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001014}
1015
Michal Kazior1bbc0972014-04-08 09:45:47 +03001016static int ath10k_monitor_vdev_delete(struct ath10k *ar)
Kalle Valo5e3dd152013-06-12 20:52:10 +03001017{
1018 int ret = 0;
1019
1020 lockdep_assert_held(&ar->conf_mutex);
1021
Kalle Valo5e3dd152013-06-12 20:52:10 +03001022 ret = ath10k_wmi_vdev_delete(ar, ar->monitor_vdev_id);
1023 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001024 ath10k_warn(ar, "failed to request wmi monitor vdev %i removal: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02001025 ar->monitor_vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001026 return ret;
1027 }
1028
Ben Greear16c11172014-09-23 14:17:16 -07001029 ar->free_vdev_map |= 1LL << ar->monitor_vdev_id;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001030
Michal Kazior7aa7a722014-08-25 12:09:38 +02001031 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac monitor vdev %d deleted\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03001032 ar->monitor_vdev_id);
1033 return ret;
1034}
1035
Michal Kazior1bbc0972014-04-08 09:45:47 +03001036static int ath10k_monitor_start(struct ath10k *ar)
1037{
1038 int ret;
1039
1040 lockdep_assert_held(&ar->conf_mutex);
1041
Michal Kazior1bbc0972014-04-08 09:45:47 +03001042 ret = ath10k_monitor_vdev_create(ar);
1043 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001044 ath10k_warn(ar, "failed to create monitor vdev: %d\n", ret);
Michal Kazior1bbc0972014-04-08 09:45:47 +03001045 return ret;
1046 }
1047
1048 ret = ath10k_monitor_vdev_start(ar, ar->monitor_vdev_id);
1049 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001050 ath10k_warn(ar, "failed to start monitor vdev: %d\n", ret);
Michal Kazior1bbc0972014-04-08 09:45:47 +03001051 ath10k_monitor_vdev_delete(ar);
1052 return ret;
1053 }
1054
1055 ar->monitor_started = true;
Michal Kazior7aa7a722014-08-25 12:09:38 +02001056 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac monitor started\n");
Michal Kazior1bbc0972014-04-08 09:45:47 +03001057
1058 return 0;
1059}
1060
Michal Kazior19337472014-08-28 12:58:16 +02001061static int ath10k_monitor_stop(struct ath10k *ar)
Michal Kazior1bbc0972014-04-08 09:45:47 +03001062{
1063 int ret;
1064
1065 lockdep_assert_held(&ar->conf_mutex);
1066
Michal Kazior1bbc0972014-04-08 09:45:47 +03001067 ret = ath10k_monitor_vdev_stop(ar);
Michal Kazior19337472014-08-28 12:58:16 +02001068 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001069 ath10k_warn(ar, "failed to stop monitor vdev: %d\n", ret);
Michal Kazior19337472014-08-28 12:58:16 +02001070 return ret;
1071 }
Michal Kazior1bbc0972014-04-08 09:45:47 +03001072
1073 ret = ath10k_monitor_vdev_delete(ar);
Michal Kazior19337472014-08-28 12:58:16 +02001074 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001075 ath10k_warn(ar, "failed to delete monitor vdev: %d\n", ret);
Michal Kazior19337472014-08-28 12:58:16 +02001076 return ret;
1077 }
Michal Kazior1bbc0972014-04-08 09:45:47 +03001078
1079 ar->monitor_started = false;
Michal Kazior7aa7a722014-08-25 12:09:38 +02001080 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac monitor stopped\n");
Michal Kazior19337472014-08-28 12:58:16 +02001081
1082 return 0;
1083}
1084
Michal Kazior500ff9f2015-03-31 10:26:21 +00001085static bool ath10k_mac_monitor_vdev_is_needed(struct ath10k *ar)
1086{
1087 int num_ctx;
1088
1089 /* At least one chanctx is required to derive a channel to start
1090 * monitor vdev on.
1091 */
1092 num_ctx = ath10k_mac_num_chanctxs(ar);
1093 if (num_ctx == 0)
1094 return false;
1095
1096 /* If there's already an existing special monitor interface then don't
1097 * bother creating another monitor vdev.
1098 */
1099 if (ar->monitor_arvif)
1100 return false;
1101
1102 return ar->monitor ||
Bob Copeland0d031c82015-09-09 12:47:34 -04001103 ar->filter_flags & FIF_OTHER_BSS ||
Michal Kazior500ff9f2015-03-31 10:26:21 +00001104 test_bit(ATH10K_CAC_RUNNING, &ar->dev_flags);
1105}
1106
1107static bool ath10k_mac_monitor_vdev_is_allowed(struct ath10k *ar)
1108{
1109 int num_ctx;
1110
1111 num_ctx = ath10k_mac_num_chanctxs(ar);
1112
1113 /* FIXME: Current interface combinations and cfg80211/mac80211 code
1114 * shouldn't allow this but make sure to prevent handling the following
1115 * case anyway since multi-channel DFS hasn't been tested at all.
1116 */
1117 if (test_bit(ATH10K_CAC_RUNNING, &ar->dev_flags) && num_ctx > 1)
1118 return false;
1119
1120 return true;
1121}
1122
Michal Kazior19337472014-08-28 12:58:16 +02001123static int ath10k_monitor_recalc(struct ath10k *ar)
1124{
Michal Kazior500ff9f2015-03-31 10:26:21 +00001125 bool needed;
1126 bool allowed;
1127 int ret;
Michal Kazior19337472014-08-28 12:58:16 +02001128
1129 lockdep_assert_held(&ar->conf_mutex);
1130
Michal Kazior500ff9f2015-03-31 10:26:21 +00001131 needed = ath10k_mac_monitor_vdev_is_needed(ar);
1132 allowed = ath10k_mac_monitor_vdev_is_allowed(ar);
Michal Kazior19337472014-08-28 12:58:16 +02001133
1134 ath10k_dbg(ar, ATH10K_DBG_MAC,
Michal Kazior500ff9f2015-03-31 10:26:21 +00001135 "mac monitor recalc started? %d needed? %d allowed? %d\n",
1136 ar->monitor_started, needed, allowed);
Michal Kazior19337472014-08-28 12:58:16 +02001137
Michal Kazior500ff9f2015-03-31 10:26:21 +00001138 if (WARN_ON(needed && !allowed)) {
1139 if (ar->monitor_started) {
1140 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac monitor stopping disallowed monitor\n");
1141
1142 ret = ath10k_monitor_stop(ar);
1143 if (ret)
Kalle Valo2a995082015-10-05 17:56:37 +03001144 ath10k_warn(ar, "failed to stop disallowed monitor: %d\n",
1145 ret);
Michal Kazior500ff9f2015-03-31 10:26:21 +00001146 /* not serious */
1147 }
1148
1149 return -EPERM;
1150 }
1151
1152 if (needed == ar->monitor_started)
Michal Kazior19337472014-08-28 12:58:16 +02001153 return 0;
1154
Michal Kazior500ff9f2015-03-31 10:26:21 +00001155 if (needed)
Michal Kazior19337472014-08-28 12:58:16 +02001156 return ath10k_monitor_start(ar);
Michal Kazior500ff9f2015-03-31 10:26:21 +00001157 else
1158 return ath10k_monitor_stop(ar);
Michal Kazior1bbc0972014-04-08 09:45:47 +03001159}
1160
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02001161static int ath10k_recalc_rtscts_prot(struct ath10k_vif *arvif)
1162{
1163 struct ath10k *ar = arvif->ar;
1164 u32 vdev_param, rts_cts = 0;
1165
1166 lockdep_assert_held(&ar->conf_mutex);
1167
1168 vdev_param = ar->wmi.vdev_param->enable_rtscts;
1169
Rajkumar Manoharan9a5ab0f2015-03-19 16:03:29 +02001170 rts_cts |= SM(WMI_RTSCTS_ENABLED, WMI_RTSCTS_SET);
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02001171
1172 if (arvif->num_legacy_stations > 0)
1173 rts_cts |= SM(WMI_RTSCTS_ACROSS_SW_RETRIES,
1174 WMI_RTSCTS_PROFILE);
Rajkumar Manoharan9a5ab0f2015-03-19 16:03:29 +02001175 else
1176 rts_cts |= SM(WMI_RTSCTS_FOR_SECOND_RATESERIES,
1177 WMI_RTSCTS_PROFILE);
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02001178
1179 return ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
1180 rts_cts);
1181}
1182
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001183static int ath10k_start_cac(struct ath10k *ar)
1184{
1185 int ret;
1186
1187 lockdep_assert_held(&ar->conf_mutex);
1188
1189 set_bit(ATH10K_CAC_RUNNING, &ar->dev_flags);
1190
Michal Kazior19337472014-08-28 12:58:16 +02001191 ret = ath10k_monitor_recalc(ar);
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001192 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001193 ath10k_warn(ar, "failed to start monitor (cac): %d\n", ret);
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001194 clear_bit(ATH10K_CAC_RUNNING, &ar->dev_flags);
1195 return ret;
1196 }
1197
Michal Kazior7aa7a722014-08-25 12:09:38 +02001198 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac cac start monitor vdev %d\n",
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001199 ar->monitor_vdev_id);
1200
1201 return 0;
1202}
1203
1204static int ath10k_stop_cac(struct ath10k *ar)
1205{
1206 lockdep_assert_held(&ar->conf_mutex);
1207
1208 /* CAC is not running - do nothing */
1209 if (!test_bit(ATH10K_CAC_RUNNING, &ar->dev_flags))
1210 return 0;
1211
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001212 clear_bit(ATH10K_CAC_RUNNING, &ar->dev_flags);
Michal Kazior1bbc0972014-04-08 09:45:47 +03001213 ath10k_monitor_stop(ar);
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001214
Michal Kazior7aa7a722014-08-25 12:09:38 +02001215 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac cac finished\n");
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001216
1217 return 0;
1218}
1219
Michal Kazior500ff9f2015-03-31 10:26:21 +00001220static void ath10k_mac_has_radar_iter(struct ieee80211_hw *hw,
1221 struct ieee80211_chanctx_conf *conf,
1222 void *data)
1223{
1224 bool *ret = data;
1225
1226 if (!*ret && conf->radar_enabled)
1227 *ret = true;
1228}
1229
1230static bool ath10k_mac_has_radar_enabled(struct ath10k *ar)
1231{
1232 bool has_radar = false;
1233
1234 ieee80211_iter_chan_contexts_atomic(ar->hw,
1235 ath10k_mac_has_radar_iter,
1236 &has_radar);
1237
1238 return has_radar;
1239}
1240
Michal Kaziord6500972014-04-08 09:56:09 +03001241static void ath10k_recalc_radar_detection(struct ath10k *ar)
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001242{
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001243 int ret;
1244
1245 lockdep_assert_held(&ar->conf_mutex);
1246
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001247 ath10k_stop_cac(ar);
1248
Michal Kazior500ff9f2015-03-31 10:26:21 +00001249 if (!ath10k_mac_has_radar_enabled(ar))
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001250 return;
1251
Michal Kaziord6500972014-04-08 09:56:09 +03001252 if (ar->num_started_vdevs > 0)
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001253 return;
1254
1255 ret = ath10k_start_cac(ar);
1256 if (ret) {
1257 /*
1258 * Not possible to start CAC on current channel so starting
1259 * radiation is not allowed, make this channel DFS_UNAVAILABLE
1260 * by indicating that radar was detected.
1261 */
Michal Kazior7aa7a722014-08-25 12:09:38 +02001262 ath10k_warn(ar, "failed to start CAC: %d\n", ret);
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001263 ieee80211_radar_detected(ar->hw);
1264 }
1265}
1266
Vasanthakumar Thiagarajan822b7e02015-03-02 17:45:27 +05301267static int ath10k_vdev_stop(struct ath10k_vif *arvif)
Michal Kazior72654fa2014-04-08 09:56:09 +03001268{
1269 struct ath10k *ar = arvif->ar;
Vasanthakumar Thiagarajan822b7e02015-03-02 17:45:27 +05301270 int ret;
1271
1272 lockdep_assert_held(&ar->conf_mutex);
1273
1274 reinit_completion(&ar->vdev_setup_done);
1275
1276 ret = ath10k_wmi_vdev_stop(ar, arvif->vdev_id);
1277 if (ret) {
1278 ath10k_warn(ar, "failed to stop WMI vdev %i: %d\n",
1279 arvif->vdev_id, ret);
1280 return ret;
1281 }
1282
1283 ret = ath10k_vdev_setup_sync(ar);
1284 if (ret) {
1285 ath10k_warn(ar, "failed to syncronise setup for vdev %i: %d\n",
1286 arvif->vdev_id, ret);
1287 return ret;
1288 }
1289
1290 WARN_ON(ar->num_started_vdevs == 0);
1291
1292 if (ar->num_started_vdevs != 0) {
1293 ar->num_started_vdevs--;
1294 ath10k_recalc_radar_detection(ar);
1295 }
1296
1297 return ret;
1298}
1299
Michal Kazior500ff9f2015-03-31 10:26:21 +00001300static int ath10k_vdev_start_restart(struct ath10k_vif *arvif,
1301 const struct cfg80211_chan_def *chandef,
1302 bool restart)
Michal Kazior72654fa2014-04-08 09:56:09 +03001303{
1304 struct ath10k *ar = arvif->ar;
Michal Kazior72654fa2014-04-08 09:56:09 +03001305 struct wmi_vdev_start_request_arg arg = {};
1306 int ret = 0;
1307
1308 lockdep_assert_held(&ar->conf_mutex);
1309
1310 reinit_completion(&ar->vdev_setup_done);
1311
1312 arg.vdev_id = arvif->vdev_id;
1313 arg.dtim_period = arvif->dtim_period;
1314 arg.bcn_intval = arvif->beacon_interval;
1315
1316 arg.channel.freq = chandef->chan->center_freq;
1317 arg.channel.band_center_freq1 = chandef->center_freq1;
1318 arg.channel.mode = chan_to_phymode(chandef);
1319
1320 arg.channel.min_power = 0;
1321 arg.channel.max_power = chandef->chan->max_power * 2;
1322 arg.channel.max_reg_power = chandef->chan->max_reg_power * 2;
1323 arg.channel.max_antenna_gain = chandef->chan->max_antenna_gain * 2;
1324
1325 if (arvif->vdev_type == WMI_VDEV_TYPE_AP) {
1326 arg.ssid = arvif->u.ap.ssid;
1327 arg.ssid_len = arvif->u.ap.ssid_len;
1328 arg.hidden_ssid = arvif->u.ap.hidden_ssid;
1329
1330 /* For now allow DFS for AP mode */
1331 arg.channel.chan_radar =
1332 !!(chandef->chan->flags & IEEE80211_CHAN_RADAR);
1333 } else if (arvif->vdev_type == WMI_VDEV_TYPE_IBSS) {
1334 arg.ssid = arvif->vif->bss_conf.ssid;
1335 arg.ssid_len = arvif->vif->bss_conf.ssid_len;
1336 }
1337
Michal Kazior7aa7a722014-08-25 12:09:38 +02001338 ath10k_dbg(ar, ATH10K_DBG_MAC,
Michal Kazior72654fa2014-04-08 09:56:09 +03001339 "mac vdev %d start center_freq %d phymode %s\n",
1340 arg.vdev_id, arg.channel.freq,
1341 ath10k_wmi_phymode_str(arg.channel.mode));
1342
Michal Kaziordc55e302014-07-29 12:53:36 +03001343 if (restart)
1344 ret = ath10k_wmi_vdev_restart(ar, &arg);
1345 else
1346 ret = ath10k_wmi_vdev_start(ar, &arg);
1347
Michal Kazior72654fa2014-04-08 09:56:09 +03001348 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001349 ath10k_warn(ar, "failed to start WMI vdev %i: %d\n",
Michal Kazior72654fa2014-04-08 09:56:09 +03001350 arg.vdev_id, ret);
1351 return ret;
1352 }
1353
1354 ret = ath10k_vdev_setup_sync(ar);
1355 if (ret) {
Ben Greear60028a82015-02-15 16:50:39 +02001356 ath10k_warn(ar,
1357 "failed to synchronize setup for vdev %i restart %d: %d\n",
1358 arg.vdev_id, restart, ret);
Michal Kazior72654fa2014-04-08 09:56:09 +03001359 return ret;
1360 }
1361
Michal Kaziord6500972014-04-08 09:56:09 +03001362 ar->num_started_vdevs++;
1363 ath10k_recalc_radar_detection(ar);
1364
Michal Kazior72654fa2014-04-08 09:56:09 +03001365 return ret;
1366}
1367
Michal Kazior500ff9f2015-03-31 10:26:21 +00001368static int ath10k_vdev_start(struct ath10k_vif *arvif,
1369 const struct cfg80211_chan_def *def)
Michal Kaziordc55e302014-07-29 12:53:36 +03001370{
Michal Kazior500ff9f2015-03-31 10:26:21 +00001371 return ath10k_vdev_start_restart(arvif, def, false);
Michal Kaziordc55e302014-07-29 12:53:36 +03001372}
1373
Michal Kazior500ff9f2015-03-31 10:26:21 +00001374static int ath10k_vdev_restart(struct ath10k_vif *arvif,
1375 const struct cfg80211_chan_def *def)
Michal Kaziordc55e302014-07-29 12:53:36 +03001376{
Michal Kazior500ff9f2015-03-31 10:26:21 +00001377 return ath10k_vdev_start_restart(arvif, def, true);
Michal Kazior72654fa2014-04-08 09:56:09 +03001378}
1379
Michal Kaziorfbb8f1b2015-01-13 16:30:12 +02001380static int ath10k_mac_setup_bcn_p2p_ie(struct ath10k_vif *arvif,
1381 struct sk_buff *bcn)
1382{
1383 struct ath10k *ar = arvif->ar;
1384 struct ieee80211_mgmt *mgmt;
1385 const u8 *p2p_ie;
1386 int ret;
1387
Peter Oh08c27be2016-01-28 13:54:09 -08001388 if (arvif->vif->type != NL80211_IFTYPE_AP || !arvif->vif->p2p)
Michal Kaziorfbb8f1b2015-01-13 16:30:12 +02001389 return 0;
1390
1391 mgmt = (void *)bcn->data;
1392 p2p_ie = cfg80211_find_vendor_ie(WLAN_OUI_WFA, WLAN_OUI_TYPE_WFA_P2P,
1393 mgmt->u.beacon.variable,
1394 bcn->len - (mgmt->u.beacon.variable -
1395 bcn->data));
1396 if (!p2p_ie)
1397 return -ENOENT;
1398
1399 ret = ath10k_wmi_p2p_go_bcn_ie(ar, arvif->vdev_id, p2p_ie);
1400 if (ret) {
1401 ath10k_warn(ar, "failed to submit p2p go bcn ie for vdev %i: %d\n",
1402 arvif->vdev_id, ret);
1403 return ret;
1404 }
1405
1406 return 0;
1407}
1408
1409static int ath10k_mac_remove_vendor_ie(struct sk_buff *skb, unsigned int oui,
1410 u8 oui_type, size_t ie_offset)
1411{
1412 size_t len;
1413 const u8 *next;
1414 const u8 *end;
1415 u8 *ie;
1416
1417 if (WARN_ON(skb->len < ie_offset))
1418 return -EINVAL;
1419
1420 ie = (u8 *)cfg80211_find_vendor_ie(oui, oui_type,
1421 skb->data + ie_offset,
1422 skb->len - ie_offset);
1423 if (!ie)
1424 return -ENOENT;
1425
1426 len = ie[1] + 2;
1427 end = skb->data + skb->len;
1428 next = ie + len;
1429
1430 if (WARN_ON(next > end))
1431 return -EINVAL;
1432
1433 memmove(ie, next, end - next);
1434 skb_trim(skb, skb->len - len);
1435
1436 return 0;
1437}
1438
1439static int ath10k_mac_setup_bcn_tmpl(struct ath10k_vif *arvif)
1440{
1441 struct ath10k *ar = arvif->ar;
1442 struct ieee80211_hw *hw = ar->hw;
1443 struct ieee80211_vif *vif = arvif->vif;
1444 struct ieee80211_mutable_offsets offs = {};
1445 struct sk_buff *bcn;
1446 int ret;
1447
1448 if (!test_bit(WMI_SERVICE_BEACON_OFFLOAD, ar->wmi.svc_map))
1449 return 0;
1450
Michal Kazior81a9a172015-03-05 16:02:17 +02001451 if (arvif->vdev_type != WMI_VDEV_TYPE_AP &&
1452 arvif->vdev_type != WMI_VDEV_TYPE_IBSS)
1453 return 0;
1454
Michal Kaziorfbb8f1b2015-01-13 16:30:12 +02001455 bcn = ieee80211_beacon_get_template(hw, vif, &offs);
1456 if (!bcn) {
1457 ath10k_warn(ar, "failed to get beacon template from mac80211\n");
1458 return -EPERM;
1459 }
1460
1461 ret = ath10k_mac_setup_bcn_p2p_ie(arvif, bcn);
1462 if (ret) {
1463 ath10k_warn(ar, "failed to setup p2p go bcn ie: %d\n", ret);
1464 kfree_skb(bcn);
1465 return ret;
1466 }
1467
1468 /* P2P IE is inserted by firmware automatically (as configured above)
1469 * so remove it from the base beacon template to avoid duplicate P2P
1470 * IEs in beacon frames.
1471 */
1472 ath10k_mac_remove_vendor_ie(bcn, WLAN_OUI_WFA, WLAN_OUI_TYPE_WFA_P2P,
1473 offsetof(struct ieee80211_mgmt,
1474 u.beacon.variable));
1475
1476 ret = ath10k_wmi_bcn_tmpl(ar, arvif->vdev_id, offs.tim_offset, bcn, 0,
1477 0, NULL, 0);
1478 kfree_skb(bcn);
1479
1480 if (ret) {
1481 ath10k_warn(ar, "failed to submit beacon template command: %d\n",
1482 ret);
1483 return ret;
1484 }
1485
1486 return 0;
1487}
1488
1489static int ath10k_mac_setup_prb_tmpl(struct ath10k_vif *arvif)
1490{
1491 struct ath10k *ar = arvif->ar;
1492 struct ieee80211_hw *hw = ar->hw;
1493 struct ieee80211_vif *vif = arvif->vif;
1494 struct sk_buff *prb;
1495 int ret;
1496
1497 if (!test_bit(WMI_SERVICE_BEACON_OFFLOAD, ar->wmi.svc_map))
1498 return 0;
1499
Michal Kazior81a9a172015-03-05 16:02:17 +02001500 if (arvif->vdev_type != WMI_VDEV_TYPE_AP)
1501 return 0;
1502
Michal Kaziorfbb8f1b2015-01-13 16:30:12 +02001503 prb = ieee80211_proberesp_get(hw, vif);
1504 if (!prb) {
1505 ath10k_warn(ar, "failed to get probe resp template from mac80211\n");
1506 return -EPERM;
1507 }
1508
1509 ret = ath10k_wmi_prb_tmpl(ar, arvif->vdev_id, prb);
1510 kfree_skb(prb);
1511
1512 if (ret) {
1513 ath10k_warn(ar, "failed to submit probe resp template command: %d\n",
1514 ret);
1515 return ret;
1516 }
1517
1518 return 0;
1519}
1520
Michal Kazior500ff9f2015-03-31 10:26:21 +00001521static int ath10k_mac_vif_fix_hidden_ssid(struct ath10k_vif *arvif)
1522{
1523 struct ath10k *ar = arvif->ar;
1524 struct cfg80211_chan_def def;
1525 int ret;
1526
1527 /* When originally vdev is started during assign_vif_chanctx() some
1528 * information is missing, notably SSID. Firmware revisions with beacon
1529 * offloading require the SSID to be provided during vdev (re)start to
1530 * handle hidden SSID properly.
1531 *
1532 * Vdev restart must be done after vdev has been both started and
1533 * upped. Otherwise some firmware revisions (at least 10.2) fail to
1534 * deliver vdev restart response event causing timeouts during vdev
1535 * syncing in ath10k.
1536 *
1537 * Note: The vdev down/up and template reinstallation could be skipped
1538 * since only wmi-tlv firmware are known to have beacon offload and
1539 * wmi-tlv doesn't seem to misbehave like 10.2 wrt vdev restart
1540 * response delivery. It's probably more robust to keep it as is.
1541 */
1542 if (!test_bit(WMI_SERVICE_BEACON_OFFLOAD, ar->wmi.svc_map))
1543 return 0;
1544
1545 if (WARN_ON(!arvif->is_started))
1546 return -EINVAL;
1547
1548 if (WARN_ON(!arvif->is_up))
1549 return -EINVAL;
1550
1551 if (WARN_ON(ath10k_mac_vif_chan(arvif->vif, &def)))
1552 return -EINVAL;
1553
1554 ret = ath10k_wmi_vdev_down(ar, arvif->vdev_id);
1555 if (ret) {
1556 ath10k_warn(ar, "failed to bring down ap vdev %i: %d\n",
1557 arvif->vdev_id, ret);
1558 return ret;
1559 }
1560
1561 /* Vdev down reset beacon & presp templates. Reinstall them. Otherwise
1562 * firmware will crash upon vdev up.
1563 */
1564
1565 ret = ath10k_mac_setup_bcn_tmpl(arvif);
1566 if (ret) {
1567 ath10k_warn(ar, "failed to update beacon template: %d\n", ret);
1568 return ret;
1569 }
1570
1571 ret = ath10k_mac_setup_prb_tmpl(arvif);
1572 if (ret) {
1573 ath10k_warn(ar, "failed to update presp template: %d\n", ret);
1574 return ret;
1575 }
1576
1577 ret = ath10k_vdev_restart(arvif, &def);
1578 if (ret) {
1579 ath10k_warn(ar, "failed to restart ap vdev %i: %d\n",
1580 arvif->vdev_id, ret);
1581 return ret;
1582 }
1583
1584 ret = ath10k_wmi_vdev_up(arvif->ar, arvif->vdev_id, arvif->aid,
1585 arvif->bssid);
1586 if (ret) {
1587 ath10k_warn(ar, "failed to bring up ap vdev %i: %d\n",
1588 arvif->vdev_id, ret);
1589 return ret;
1590 }
1591
1592 return 0;
1593}
1594
Kalle Valo5e3dd152013-06-12 20:52:10 +03001595static void ath10k_control_beaconing(struct ath10k_vif *arvif,
Kalle Valo5b07e072014-09-14 12:50:06 +03001596 struct ieee80211_bss_conf *info)
Kalle Valo5e3dd152013-06-12 20:52:10 +03001597{
Michal Kazior7aa7a722014-08-25 12:09:38 +02001598 struct ath10k *ar = arvif->ar;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001599 int ret = 0;
1600
Michal Kazior548db542013-07-05 16:15:15 +03001601 lockdep_assert_held(&arvif->ar->conf_mutex);
1602
Kalle Valo5e3dd152013-06-12 20:52:10 +03001603 if (!info->enable_beacon) {
Michal Kazior500ff9f2015-03-31 10:26:21 +00001604 ret = ath10k_wmi_vdev_down(ar, arvif->vdev_id);
1605 if (ret)
1606 ath10k_warn(ar, "failed to down vdev_id %i: %d\n",
1607 arvif->vdev_id, ret);
Michal Kaziorc930f742014-01-23 11:38:25 +01001608
Michal Kaziorc930f742014-01-23 11:38:25 +01001609 arvif->is_up = false;
1610
Michal Kazior748afc42014-01-23 12:48:21 +01001611 spin_lock_bh(&arvif->ar->data_lock);
Michal Kazior64badcb2014-09-18 11:18:02 +03001612 ath10k_mac_vif_beacon_free(arvif);
Michal Kazior748afc42014-01-23 12:48:21 +01001613 spin_unlock_bh(&arvif->ar->data_lock);
1614
Kalle Valo5e3dd152013-06-12 20:52:10 +03001615 return;
1616 }
1617
1618 arvif->tx_seq_no = 0x1000;
1619
Michal Kaziorc930f742014-01-23 11:38:25 +01001620 arvif->aid = 0;
Kalle Valob25f32c2014-09-14 12:50:49 +03001621 ether_addr_copy(arvif->bssid, info->bssid);
Michal Kaziorc930f742014-01-23 11:38:25 +01001622
1623 ret = ath10k_wmi_vdev_up(arvif->ar, arvif->vdev_id, arvif->aid,
1624 arvif->bssid);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001625 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001626 ath10k_warn(ar, "failed to bring up vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02001627 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001628 return;
1629 }
Michal Kaziorc930f742014-01-23 11:38:25 +01001630
Michal Kaziorc930f742014-01-23 11:38:25 +01001631 arvif->is_up = true;
1632
Michal Kazior500ff9f2015-03-31 10:26:21 +00001633 ret = ath10k_mac_vif_fix_hidden_ssid(arvif);
1634 if (ret) {
1635 ath10k_warn(ar, "failed to fix hidden ssid for vdev %i, expect trouble: %d\n",
1636 arvif->vdev_id, ret);
1637 return;
1638 }
1639
Michal Kazior7aa7a722014-08-25 12:09:38 +02001640 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %d up\n", arvif->vdev_id);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001641}
1642
1643static void ath10k_control_ibss(struct ath10k_vif *arvif,
1644 struct ieee80211_bss_conf *info,
1645 const u8 self_peer[ETH_ALEN])
1646{
Michal Kazior7aa7a722014-08-25 12:09:38 +02001647 struct ath10k *ar = arvif->ar;
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02001648 u32 vdev_param;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001649 int ret = 0;
1650
Michal Kazior548db542013-07-05 16:15:15 +03001651 lockdep_assert_held(&arvif->ar->conf_mutex);
1652
Kalle Valo5e3dd152013-06-12 20:52:10 +03001653 if (!info->ibss_joined) {
Michal Kaziorc930f742014-01-23 11:38:25 +01001654 if (is_zero_ether_addr(arvif->bssid))
Kalle Valo5e3dd152013-06-12 20:52:10 +03001655 return;
1656
Joe Perches93803b32015-03-02 19:54:49 -08001657 eth_zero_addr(arvif->bssid);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001658
1659 return;
1660 }
1661
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02001662 vdev_param = arvif->ar->wmi.vdev_param->atim_window;
1663 ret = ath10k_wmi_vdev_set_param(arvif->ar, arvif->vdev_id, vdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03001664 ATH10K_DEFAULT_ATIM);
1665 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02001666 ath10k_warn(ar, "failed to set IBSS ATIM for vdev %d: %d\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03001667 arvif->vdev_id, ret);
1668}
1669
Michal Kazior9f9b5742014-12-12 12:41:36 +01001670static int ath10k_mac_vif_recalc_ps_wake_threshold(struct ath10k_vif *arvif)
1671{
1672 struct ath10k *ar = arvif->ar;
1673 u32 param;
1674 u32 value;
1675 int ret;
1676
1677 lockdep_assert_held(&arvif->ar->conf_mutex);
1678
1679 if (arvif->u.sta.uapsd)
1680 value = WMI_STA_PS_TX_WAKE_THRESHOLD_NEVER;
1681 else
1682 value = WMI_STA_PS_TX_WAKE_THRESHOLD_ALWAYS;
1683
1684 param = WMI_STA_PS_PARAM_TX_WAKE_THRESHOLD;
1685 ret = ath10k_wmi_set_sta_ps_param(ar, arvif->vdev_id, param, value);
1686 if (ret) {
1687 ath10k_warn(ar, "failed to submit ps wake threshold %u on vdev %i: %d\n",
1688 value, arvif->vdev_id, ret);
1689 return ret;
1690 }
1691
1692 return 0;
1693}
1694
1695static int ath10k_mac_vif_recalc_ps_poll_count(struct ath10k_vif *arvif)
1696{
1697 struct ath10k *ar = arvif->ar;
1698 u32 param;
1699 u32 value;
1700 int ret;
1701
1702 lockdep_assert_held(&arvif->ar->conf_mutex);
1703
1704 if (arvif->u.sta.uapsd)
1705 value = WMI_STA_PS_PSPOLL_COUNT_UAPSD;
1706 else
1707 value = WMI_STA_PS_PSPOLL_COUNT_NO_MAX;
1708
1709 param = WMI_STA_PS_PARAM_PSPOLL_COUNT;
1710 ret = ath10k_wmi_set_sta_ps_param(ar, arvif->vdev_id,
1711 param, value);
1712 if (ret) {
1713 ath10k_warn(ar, "failed to submit ps poll count %u on vdev %i: %d\n",
1714 value, arvif->vdev_id, ret);
1715 return ret;
1716 }
1717
1718 return 0;
1719}
1720
Michal Kazior424f2632015-07-09 13:08:35 +02001721static int ath10k_mac_num_vifs_started(struct ath10k *ar)
Michal Kaziorcffb41f2015-02-13 13:30:16 +01001722{
1723 struct ath10k_vif *arvif;
1724 int num = 0;
1725
1726 lockdep_assert_held(&ar->conf_mutex);
1727
1728 list_for_each_entry(arvif, &ar->arvifs, list)
Michal Kazior424f2632015-07-09 13:08:35 +02001729 if (arvif->is_started)
Michal Kaziorcffb41f2015-02-13 13:30:16 +01001730 num++;
1731
1732 return num;
1733}
1734
Michal Kaziorad088bf2013-10-16 15:44:46 +03001735static int ath10k_mac_vif_setup_ps(struct ath10k_vif *arvif)
Kalle Valo5e3dd152013-06-12 20:52:10 +03001736{
Michal Kaziorad088bf2013-10-16 15:44:46 +03001737 struct ath10k *ar = arvif->ar;
Michal Kazior526549a2014-12-12 12:41:37 +01001738 struct ieee80211_vif *vif = arvif->vif;
Michal Kaziorad088bf2013-10-16 15:44:46 +03001739 struct ieee80211_conf *conf = &ar->hw->conf;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001740 enum wmi_sta_powersave_param param;
1741 enum wmi_sta_ps_mode psmode;
1742 int ret;
Michal Kazior526549a2014-12-12 12:41:37 +01001743 int ps_timeout;
Michal Kaziorcffb41f2015-02-13 13:30:16 +01001744 bool enable_ps;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001745
Michal Kazior548db542013-07-05 16:15:15 +03001746 lockdep_assert_held(&arvif->ar->conf_mutex);
1747
Michal Kaziorad088bf2013-10-16 15:44:46 +03001748 if (arvif->vif->type != NL80211_IFTYPE_STATION)
1749 return 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001750
Michal Kaziorcffb41f2015-02-13 13:30:16 +01001751 enable_ps = arvif->ps;
1752
Michal Kazior424f2632015-07-09 13:08:35 +02001753 if (enable_ps && ath10k_mac_num_vifs_started(ar) > 1 &&
Michal Kaziorcffb41f2015-02-13 13:30:16 +01001754 !test_bit(ATH10K_FW_FEATURE_MULTI_VIF_PS_SUPPORT,
1755 ar->fw_features)) {
1756 ath10k_warn(ar, "refusing to enable ps on vdev %i: not supported by fw\n",
1757 arvif->vdev_id);
1758 enable_ps = false;
1759 }
1760
Janusz Dziedzic917826b2015-05-18 09:38:17 +00001761 if (!arvif->is_started) {
1762 /* mac80211 can update vif powersave state while disconnected.
1763 * Firmware doesn't behave nicely and consumes more power than
1764 * necessary if PS is disabled on a non-started vdev. Hence
1765 * force-enable PS for non-running vdevs.
1766 */
1767 psmode = WMI_STA_PS_MODE_ENABLED;
1768 } else if (enable_ps) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03001769 psmode = WMI_STA_PS_MODE_ENABLED;
1770 param = WMI_STA_PS_PARAM_INACTIVITY_TIME;
1771
Michal Kazior526549a2014-12-12 12:41:37 +01001772 ps_timeout = conf->dynamic_ps_timeout;
1773 if (ps_timeout == 0) {
1774 /* Firmware doesn't like 0 */
1775 ps_timeout = ieee80211_tu_to_usec(
1776 vif->bss_conf.beacon_int) / 1000;
1777 }
1778
Michal Kaziorad088bf2013-10-16 15:44:46 +03001779 ret = ath10k_wmi_set_sta_ps_param(ar, arvif->vdev_id, param,
Michal Kazior526549a2014-12-12 12:41:37 +01001780 ps_timeout);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001781 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001782 ath10k_warn(ar, "failed to set inactivity time for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02001783 arvif->vdev_id, ret);
Michal Kaziorad088bf2013-10-16 15:44:46 +03001784 return ret;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001785 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03001786 } else {
1787 psmode = WMI_STA_PS_MODE_DISABLED;
1788 }
1789
Michal Kazior7aa7a722014-08-25 12:09:38 +02001790 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %d psmode %s\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03001791 arvif->vdev_id, psmode ? "enable" : "disable");
1792
Michal Kaziorad088bf2013-10-16 15:44:46 +03001793 ret = ath10k_wmi_set_psmode(ar, arvif->vdev_id, psmode);
1794 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001795 ath10k_warn(ar, "failed to set PS Mode %d for vdev %d: %d\n",
Kalle Valobe6546f2014-03-25 14:18:51 +02001796 psmode, arvif->vdev_id, ret);
Michal Kaziorad088bf2013-10-16 15:44:46 +03001797 return ret;
1798 }
1799
1800 return 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001801}
1802
Michal Kazior46725b152015-01-28 09:57:49 +02001803static int ath10k_mac_vif_disable_keepalive(struct ath10k_vif *arvif)
1804{
1805 struct ath10k *ar = arvif->ar;
1806 struct wmi_sta_keepalive_arg arg = {};
1807 int ret;
1808
1809 lockdep_assert_held(&arvif->ar->conf_mutex);
1810
1811 if (arvif->vdev_type != WMI_VDEV_TYPE_STA)
1812 return 0;
1813
1814 if (!test_bit(WMI_SERVICE_STA_KEEP_ALIVE, ar->wmi.svc_map))
1815 return 0;
1816
1817 /* Some firmware revisions have a bug and ignore the `enabled` field.
1818 * Instead use the interval to disable the keepalive.
1819 */
1820 arg.vdev_id = arvif->vdev_id;
1821 arg.enabled = 1;
1822 arg.method = WMI_STA_KEEPALIVE_METHOD_NULL_FRAME;
1823 arg.interval = WMI_STA_KEEPALIVE_INTERVAL_DISABLE;
1824
1825 ret = ath10k_wmi_sta_keepalive(ar, &arg);
1826 if (ret) {
1827 ath10k_warn(ar, "failed to submit keepalive on vdev %i: %d\n",
1828 arvif->vdev_id, ret);
1829 return ret;
1830 }
1831
1832 return 0;
1833}
1834
Michal Kazior81a9a172015-03-05 16:02:17 +02001835static void ath10k_mac_vif_ap_csa_count_down(struct ath10k_vif *arvif)
1836{
1837 struct ath10k *ar = arvif->ar;
1838 struct ieee80211_vif *vif = arvif->vif;
1839 int ret;
1840
Michal Kazior8513d952015-03-09 14:19:24 +01001841 lockdep_assert_held(&arvif->ar->conf_mutex);
1842
1843 if (WARN_ON(!test_bit(WMI_SERVICE_BEACON_OFFLOAD, ar->wmi.svc_map)))
1844 return;
1845
Michal Kazior81a9a172015-03-05 16:02:17 +02001846 if (arvif->vdev_type != WMI_VDEV_TYPE_AP)
1847 return;
1848
1849 if (!vif->csa_active)
1850 return;
1851
1852 if (!arvif->is_up)
1853 return;
1854
1855 if (!ieee80211_csa_is_complete(vif)) {
1856 ieee80211_csa_update_counter(vif);
1857
1858 ret = ath10k_mac_setup_bcn_tmpl(arvif);
1859 if (ret)
1860 ath10k_warn(ar, "failed to update bcn tmpl during csa: %d\n",
1861 ret);
1862
1863 ret = ath10k_mac_setup_prb_tmpl(arvif);
1864 if (ret)
1865 ath10k_warn(ar, "failed to update prb tmpl during csa: %d\n",
1866 ret);
1867 } else {
1868 ieee80211_csa_finish(vif);
1869 }
1870}
1871
1872static void ath10k_mac_vif_ap_csa_work(struct work_struct *work)
1873{
1874 struct ath10k_vif *arvif = container_of(work, struct ath10k_vif,
1875 ap_csa_work);
1876 struct ath10k *ar = arvif->ar;
1877
1878 mutex_lock(&ar->conf_mutex);
1879 ath10k_mac_vif_ap_csa_count_down(arvif);
1880 mutex_unlock(&ar->conf_mutex);
1881}
1882
Michal Kaziorcc9904e2015-03-10 16:22:01 +02001883static void ath10k_mac_handle_beacon_iter(void *data, u8 *mac,
1884 struct ieee80211_vif *vif)
1885{
1886 struct sk_buff *skb = data;
1887 struct ieee80211_mgmt *mgmt = (void *)skb->data;
1888 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
1889
1890 if (vif->type != NL80211_IFTYPE_STATION)
1891 return;
1892
1893 if (!ether_addr_equal(mgmt->bssid, vif->bss_conf.bssid))
1894 return;
1895
1896 cancel_delayed_work(&arvif->connection_loss_work);
1897}
1898
1899void ath10k_mac_handle_beacon(struct ath10k *ar, struct sk_buff *skb)
1900{
1901 ieee80211_iterate_active_interfaces_atomic(ar->hw,
1902 IEEE80211_IFACE_ITER_NORMAL,
1903 ath10k_mac_handle_beacon_iter,
1904 skb);
1905}
1906
1907static void ath10k_mac_handle_beacon_miss_iter(void *data, u8 *mac,
1908 struct ieee80211_vif *vif)
1909{
1910 u32 *vdev_id = data;
1911 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
1912 struct ath10k *ar = arvif->ar;
1913 struct ieee80211_hw *hw = ar->hw;
1914
1915 if (arvif->vdev_id != *vdev_id)
1916 return;
1917
1918 if (!arvif->is_up)
1919 return;
1920
1921 ieee80211_beacon_loss(vif);
1922
1923 /* Firmware doesn't report beacon loss events repeatedly. If AP probe
1924 * (done by mac80211) succeeds but beacons do not resume then it
1925 * doesn't make sense to continue operation. Queue connection loss work
1926 * which can be cancelled when beacon is received.
1927 */
1928 ieee80211_queue_delayed_work(hw, &arvif->connection_loss_work,
1929 ATH10K_CONNECTION_LOSS_HZ);
1930}
1931
1932void ath10k_mac_handle_beacon_miss(struct ath10k *ar, u32 vdev_id)
1933{
1934 ieee80211_iterate_active_interfaces_atomic(ar->hw,
1935 IEEE80211_IFACE_ITER_NORMAL,
1936 ath10k_mac_handle_beacon_miss_iter,
1937 &vdev_id);
1938}
1939
1940static void ath10k_mac_vif_sta_connection_loss_work(struct work_struct *work)
1941{
1942 struct ath10k_vif *arvif = container_of(work, struct ath10k_vif,
1943 connection_loss_work.work);
1944 struct ieee80211_vif *vif = arvif->vif;
1945
1946 if (!arvif->is_up)
1947 return;
1948
1949 ieee80211_connection_loss(vif);
1950}
1951
Kalle Valo5e3dd152013-06-12 20:52:10 +03001952/**********************/
1953/* Station management */
1954/**********************/
1955
Michal Kazior590922a2014-10-21 10:10:29 +03001956static u32 ath10k_peer_assoc_h_listen_intval(struct ath10k *ar,
1957 struct ieee80211_vif *vif)
1958{
1959 /* Some firmware revisions have unstable STA powersave when listen
1960 * interval is set too high (e.g. 5). The symptoms are firmware doesn't
1961 * generate NullFunc frames properly even if buffered frames have been
1962 * indicated in Beacon TIM. Firmware would seldom wake up to pull
1963 * buffered frames. Often pinging the device from AP would simply fail.
1964 *
1965 * As a workaround set it to 1.
1966 */
1967 if (vif->type == NL80211_IFTYPE_STATION)
1968 return 1;
1969
1970 return ar->hw->conf.listen_interval;
1971}
1972
Kalle Valo5e3dd152013-06-12 20:52:10 +03001973static void ath10k_peer_assoc_h_basic(struct ath10k *ar,
Michal Kazior590922a2014-10-21 10:10:29 +03001974 struct ieee80211_vif *vif,
Kalle Valo5e3dd152013-06-12 20:52:10 +03001975 struct ieee80211_sta *sta,
Kalle Valo5e3dd152013-06-12 20:52:10 +03001976 struct wmi_peer_assoc_complete_arg *arg)
1977{
Michal Kazior590922a2014-10-21 10:10:29 +03001978 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kaziorc51880e2015-03-30 09:51:57 +03001979 u32 aid;
Michal Kazior590922a2014-10-21 10:10:29 +03001980
Michal Kazior548db542013-07-05 16:15:15 +03001981 lockdep_assert_held(&ar->conf_mutex);
1982
Michal Kaziorc51880e2015-03-30 09:51:57 +03001983 if (vif->type == NL80211_IFTYPE_STATION)
1984 aid = vif->bss_conf.aid;
1985 else
1986 aid = sta->aid;
1987
Kalle Valob25f32c2014-09-14 12:50:49 +03001988 ether_addr_copy(arg->addr, sta->addr);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001989 arg->vdev_id = arvif->vdev_id;
Michal Kaziorc51880e2015-03-30 09:51:57 +03001990 arg->peer_aid = aid;
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02001991 arg->peer_flags |= arvif->ar->wmi.peer_flags->auth;
Michal Kazior590922a2014-10-21 10:10:29 +03001992 arg->peer_listen_intval = ath10k_peer_assoc_h_listen_intval(ar, vif);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001993 arg->peer_num_spatial_streams = 1;
Michal Kazior590922a2014-10-21 10:10:29 +03001994 arg->peer_caps = vif->bss_conf.assoc_capability;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001995}
1996
1997static void ath10k_peer_assoc_h_crypto(struct ath10k *ar,
Michal Kazior590922a2014-10-21 10:10:29 +03001998 struct ieee80211_vif *vif,
Tamizh chelvam90eceb32015-10-29 14:27:42 +02001999 struct ieee80211_sta *sta,
Kalle Valo5e3dd152013-06-12 20:52:10 +03002000 struct wmi_peer_assoc_complete_arg *arg)
2001{
Kalle Valo5e3dd152013-06-12 20:52:10 +03002002 struct ieee80211_bss_conf *info = &vif->bss_conf;
Michal Kazior500ff9f2015-03-31 10:26:21 +00002003 struct cfg80211_chan_def def;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002004 struct cfg80211_bss *bss;
2005 const u8 *rsnie = NULL;
2006 const u8 *wpaie = NULL;
2007
Michal Kazior548db542013-07-05 16:15:15 +03002008 lockdep_assert_held(&ar->conf_mutex);
2009
Michal Kazior500ff9f2015-03-31 10:26:21 +00002010 if (WARN_ON(ath10k_mac_vif_chan(vif, &def)))
2011 return;
2012
2013 bss = cfg80211_get_bss(ar->hw->wiphy, def.chan, info->bssid, NULL, 0,
2014 IEEE80211_BSS_TYPE_ANY, IEEE80211_PRIVACY_ANY);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002015 if (bss) {
2016 const struct cfg80211_bss_ies *ies;
2017
2018 rcu_read_lock();
2019 rsnie = ieee80211_bss_get_ie(bss, WLAN_EID_RSN);
2020
2021 ies = rcu_dereference(bss->ies);
2022
2023 wpaie = cfg80211_find_vendor_ie(WLAN_OUI_MICROSOFT,
Kalle Valo5b07e072014-09-14 12:50:06 +03002024 WLAN_OUI_TYPE_MICROSOFT_WPA,
2025 ies->data,
2026 ies->len);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002027 rcu_read_unlock();
2028 cfg80211_put_bss(ar->hw->wiphy, bss);
2029 }
2030
2031 /* FIXME: base on RSN IE/WPA IE is a correct idea? */
2032 if (rsnie || wpaie) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002033 ath10k_dbg(ar, ATH10K_DBG_WMI, "%s: rsn ie found\n", __func__);
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002034 arg->peer_flags |= ar->wmi.peer_flags->need_ptk_4_way;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002035 }
2036
2037 if (wpaie) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002038 ath10k_dbg(ar, ATH10K_DBG_WMI, "%s: wpa ie found\n", __func__);
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002039 arg->peer_flags |= ar->wmi.peer_flags->need_gtk_2_way;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002040 }
Tamizh chelvam90eceb32015-10-29 14:27:42 +02002041
2042 if (sta->mfp &&
2043 test_bit(ATH10K_FW_FEATURE_MFP_SUPPORT, ar->fw_features)) {
2044 arg->peer_flags |= ar->wmi.peer_flags->pmf;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002045 }
2046}
2047
2048static void ath10k_peer_assoc_h_rates(struct ath10k *ar,
Michal Kazior500ff9f2015-03-31 10:26:21 +00002049 struct ieee80211_vif *vif,
Kalle Valo5e3dd152013-06-12 20:52:10 +03002050 struct ieee80211_sta *sta,
2051 struct wmi_peer_assoc_complete_arg *arg)
2052{
Michal Kazior45c9abc2015-04-21 20:42:58 +03002053 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002054 struct wmi_rate_set_arg *rateset = &arg->peer_legacy_rates;
Michal Kazior500ff9f2015-03-31 10:26:21 +00002055 struct cfg80211_chan_def def;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002056 const struct ieee80211_supported_band *sband;
2057 const struct ieee80211_rate *rates;
Michal Kazior45c9abc2015-04-21 20:42:58 +03002058 enum ieee80211_band band;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002059 u32 ratemask;
Michal Kazior486017c2015-03-30 09:51:54 +03002060 u8 rate;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002061 int i;
2062
Michal Kazior548db542013-07-05 16:15:15 +03002063 lockdep_assert_held(&ar->conf_mutex);
2064
Michal Kazior500ff9f2015-03-31 10:26:21 +00002065 if (WARN_ON(ath10k_mac_vif_chan(vif, &def)))
2066 return;
2067
Michal Kazior45c9abc2015-04-21 20:42:58 +03002068 band = def.chan->band;
2069 sband = ar->hw->wiphy->bands[band];
2070 ratemask = sta->supp_rates[band];
2071 ratemask &= arvif->bitrate_mask.control[band].legacy;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002072 rates = sband->bitrates;
2073
2074 rateset->num_rates = 0;
2075
2076 for (i = 0; i < 32; i++, ratemask >>= 1, rates++) {
2077 if (!(ratemask & 1))
2078 continue;
2079
Michal Kazior486017c2015-03-30 09:51:54 +03002080 rate = ath10k_mac_bitrate_to_rate(rates->bitrate);
2081 rateset->rates[rateset->num_rates] = rate;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002082 rateset->num_rates++;
2083 }
2084}
2085
Michal Kazior45c9abc2015-04-21 20:42:58 +03002086static bool
2087ath10k_peer_assoc_h_ht_masked(const u8 ht_mcs_mask[IEEE80211_HT_MCS_MASK_LEN])
2088{
2089 int nss;
2090
2091 for (nss = 0; nss < IEEE80211_HT_MCS_MASK_LEN; nss++)
2092 if (ht_mcs_mask[nss])
2093 return false;
2094
2095 return true;
2096}
2097
2098static bool
2099ath10k_peer_assoc_h_vht_masked(const u16 vht_mcs_mask[NL80211_VHT_NSS_MAX])
2100{
2101 int nss;
2102
2103 for (nss = 0; nss < NL80211_VHT_NSS_MAX; nss++)
2104 if (vht_mcs_mask[nss])
2105 return false;
2106
2107 return true;
2108}
2109
Kalle Valo5e3dd152013-06-12 20:52:10 +03002110static void ath10k_peer_assoc_h_ht(struct ath10k *ar,
Michal Kazior45c9abc2015-04-21 20:42:58 +03002111 struct ieee80211_vif *vif,
Kalle Valo5e3dd152013-06-12 20:52:10 +03002112 struct ieee80211_sta *sta,
2113 struct wmi_peer_assoc_complete_arg *arg)
2114{
2115 const struct ieee80211_sta_ht_cap *ht_cap = &sta->ht_cap;
Michal Kazior45c9abc2015-04-21 20:42:58 +03002116 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
2117 struct cfg80211_chan_def def;
2118 enum ieee80211_band band;
2119 const u8 *ht_mcs_mask;
2120 const u16 *vht_mcs_mask;
Vivek Natarajan72f8cef2015-10-06 15:19:34 +03002121 int i, n;
2122 u8 max_nss;
Kalle Valoaf762c02014-09-14 12:50:17 +03002123 u32 stbc;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002124
Michal Kazior548db542013-07-05 16:15:15 +03002125 lockdep_assert_held(&ar->conf_mutex);
2126
Michal Kazior45c9abc2015-04-21 20:42:58 +03002127 if (WARN_ON(ath10k_mac_vif_chan(vif, &def)))
2128 return;
2129
Kalle Valo5e3dd152013-06-12 20:52:10 +03002130 if (!ht_cap->ht_supported)
2131 return;
2132
Michal Kazior45c9abc2015-04-21 20:42:58 +03002133 band = def.chan->band;
2134 ht_mcs_mask = arvif->bitrate_mask.control[band].ht_mcs;
2135 vht_mcs_mask = arvif->bitrate_mask.control[band].vht_mcs;
2136
2137 if (ath10k_peer_assoc_h_ht_masked(ht_mcs_mask) &&
2138 ath10k_peer_assoc_h_vht_masked(vht_mcs_mask))
2139 return;
2140
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002141 arg->peer_flags |= ar->wmi.peer_flags->ht;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002142 arg->peer_max_mpdu = (1 << (IEEE80211_HT_MAX_AMPDU_FACTOR +
2143 ht_cap->ampdu_factor)) - 1;
2144
2145 arg->peer_mpdu_density =
2146 ath10k_parse_mpdudensity(ht_cap->ampdu_density);
2147
2148 arg->peer_ht_caps = ht_cap->cap;
2149 arg->peer_rate_caps |= WMI_RC_HT_FLAG;
2150
2151 if (ht_cap->cap & IEEE80211_HT_CAP_LDPC_CODING)
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002152 arg->peer_flags |= ar->wmi.peer_flags->ldbc;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002153
2154 if (sta->bandwidth >= IEEE80211_STA_RX_BW_40) {
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002155 arg->peer_flags |= ar->wmi.peer_flags->bw40;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002156 arg->peer_rate_caps |= WMI_RC_CW40_FLAG;
2157 }
2158
Michal Kazior45c9abc2015-04-21 20:42:58 +03002159 if (arvif->bitrate_mask.control[band].gi != NL80211_TXRATE_FORCE_LGI) {
2160 if (ht_cap->cap & IEEE80211_HT_CAP_SGI_20)
2161 arg->peer_rate_caps |= WMI_RC_SGI_FLAG;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002162
Michal Kazior45c9abc2015-04-21 20:42:58 +03002163 if (ht_cap->cap & IEEE80211_HT_CAP_SGI_40)
2164 arg->peer_rate_caps |= WMI_RC_SGI_FLAG;
2165 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002166
2167 if (ht_cap->cap & IEEE80211_HT_CAP_TX_STBC) {
2168 arg->peer_rate_caps |= WMI_RC_TX_STBC_FLAG;
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002169 arg->peer_flags |= ar->wmi.peer_flags->stbc;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002170 }
2171
2172 if (ht_cap->cap & IEEE80211_HT_CAP_RX_STBC) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03002173 stbc = ht_cap->cap & IEEE80211_HT_CAP_RX_STBC;
2174 stbc = stbc >> IEEE80211_HT_CAP_RX_STBC_SHIFT;
2175 stbc = stbc << WMI_RC_RX_STBC_FLAG_S;
2176 arg->peer_rate_caps |= stbc;
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002177 arg->peer_flags |= ar->wmi.peer_flags->stbc;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002178 }
2179
Kalle Valo5e3dd152013-06-12 20:52:10 +03002180 if (ht_cap->mcs.rx_mask[1] && ht_cap->mcs.rx_mask[2])
2181 arg->peer_rate_caps |= WMI_RC_TS_FLAG;
2182 else if (ht_cap->mcs.rx_mask[1])
2183 arg->peer_rate_caps |= WMI_RC_DS_FLAG;
2184
Michal Kazior45c9abc2015-04-21 20:42:58 +03002185 for (i = 0, n = 0, max_nss = 0; i < IEEE80211_HT_MCS_MASK_LEN * 8; i++)
2186 if ((ht_cap->mcs.rx_mask[i / 8] & BIT(i % 8)) &&
2187 (ht_mcs_mask[i / 8] & BIT(i % 8))) {
2188 max_nss = (i / 8) + 1;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002189 arg->peer_ht_rates.rates[n++] = i;
Michal Kazior45c9abc2015-04-21 20:42:58 +03002190 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002191
Bartosz Markowskifd71f802014-02-10 13:12:55 +01002192 /*
2193 * This is a workaround for HT-enabled STAs which break the spec
2194 * and have no HT capabilities RX mask (no HT RX MCS map).
2195 *
2196 * As per spec, in section 20.3.5 Modulation and coding scheme (MCS),
2197 * MCS 0 through 7 are mandatory in 20MHz with 800 ns GI at all STAs.
2198 *
2199 * Firmware asserts if such situation occurs.
2200 */
2201 if (n == 0) {
2202 arg->peer_ht_rates.num_rates = 8;
2203 for (i = 0; i < arg->peer_ht_rates.num_rates; i++)
2204 arg->peer_ht_rates.rates[i] = i;
2205 } else {
2206 arg->peer_ht_rates.num_rates = n;
Vivek Natarajan72f8cef2015-10-06 15:19:34 +03002207 arg->peer_num_spatial_streams = min(sta->rx_nss, max_nss);
Bartosz Markowskifd71f802014-02-10 13:12:55 +01002208 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002209
Michal Kazior7aa7a722014-08-25 12:09:38 +02002210 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac ht peer %pM mcs cnt %d nss %d\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03002211 arg->addr,
Kalle Valo5e3dd152013-06-12 20:52:10 +03002212 arg->peer_ht_rates.num_rates,
2213 arg->peer_num_spatial_streams);
2214}
2215
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002216static int ath10k_peer_assoc_qos_ap(struct ath10k *ar,
2217 struct ath10k_vif *arvif,
2218 struct ieee80211_sta *sta)
Kalle Valo5e3dd152013-06-12 20:52:10 +03002219{
2220 u32 uapsd = 0;
2221 u32 max_sp = 0;
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002222 int ret = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002223
Michal Kazior548db542013-07-05 16:15:15 +03002224 lockdep_assert_held(&ar->conf_mutex);
2225
Kalle Valo5e3dd152013-06-12 20:52:10 +03002226 if (sta->wme && sta->uapsd_queues) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002227 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac uapsd_queues 0x%x max_sp %d\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03002228 sta->uapsd_queues, sta->max_sp);
2229
Kalle Valo5e3dd152013-06-12 20:52:10 +03002230 if (sta->uapsd_queues & IEEE80211_WMM_IE_STA_QOSINFO_AC_VO)
2231 uapsd |= WMI_AP_PS_UAPSD_AC3_DELIVERY_EN |
2232 WMI_AP_PS_UAPSD_AC3_TRIGGER_EN;
2233 if (sta->uapsd_queues & IEEE80211_WMM_IE_STA_QOSINFO_AC_VI)
2234 uapsd |= WMI_AP_PS_UAPSD_AC2_DELIVERY_EN |
2235 WMI_AP_PS_UAPSD_AC2_TRIGGER_EN;
2236 if (sta->uapsd_queues & IEEE80211_WMM_IE_STA_QOSINFO_AC_BK)
2237 uapsd |= WMI_AP_PS_UAPSD_AC1_DELIVERY_EN |
2238 WMI_AP_PS_UAPSD_AC1_TRIGGER_EN;
2239 if (sta->uapsd_queues & IEEE80211_WMM_IE_STA_QOSINFO_AC_BE)
2240 uapsd |= WMI_AP_PS_UAPSD_AC0_DELIVERY_EN |
2241 WMI_AP_PS_UAPSD_AC0_TRIGGER_EN;
2242
Kalle Valo5e3dd152013-06-12 20:52:10 +03002243 if (sta->max_sp < MAX_WMI_AP_PS_PEER_PARAM_MAX_SP)
2244 max_sp = sta->max_sp;
2245
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002246 ret = ath10k_wmi_set_ap_ps_param(ar, arvif->vdev_id,
2247 sta->addr,
2248 WMI_AP_PS_PEER_PARAM_UAPSD,
2249 uapsd);
2250 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002251 ath10k_warn(ar, "failed to set ap ps peer param uapsd for vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02002252 arvif->vdev_id, ret);
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002253 return ret;
2254 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002255
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002256 ret = ath10k_wmi_set_ap_ps_param(ar, arvif->vdev_id,
2257 sta->addr,
2258 WMI_AP_PS_PEER_PARAM_MAX_SP,
2259 max_sp);
2260 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002261 ath10k_warn(ar, "failed to set ap ps peer param max sp for vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02002262 arvif->vdev_id, ret);
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002263 return ret;
2264 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002265
2266 /* TODO setup this based on STA listen interval and
2267 beacon interval. Currently we don't know
2268 sta->listen_interval - mac80211 patch required.
2269 Currently use 10 seconds */
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002270 ret = ath10k_wmi_set_ap_ps_param(ar, arvif->vdev_id, sta->addr,
Kalle Valo5b07e072014-09-14 12:50:06 +03002271 WMI_AP_PS_PEER_PARAM_AGEOUT_TIME,
2272 10);
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002273 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002274 ath10k_warn(ar, "failed to set ap ps peer param ageout time for vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02002275 arvif->vdev_id, ret);
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002276 return ret;
2277 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002278 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002279
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002280 return 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002281}
2282
Michal Kazior45c9abc2015-04-21 20:42:58 +03002283static u16
2284ath10k_peer_assoc_h_vht_limit(u16 tx_mcs_set,
2285 const u16 vht_mcs_limit[NL80211_VHT_NSS_MAX])
2286{
2287 int idx_limit;
2288 int nss;
2289 u16 mcs_map;
2290 u16 mcs;
2291
2292 for (nss = 0; nss < NL80211_VHT_NSS_MAX; nss++) {
2293 mcs_map = ath10k_mac_get_max_vht_mcs_map(tx_mcs_set, nss) &
2294 vht_mcs_limit[nss];
2295
2296 if (mcs_map)
2297 idx_limit = fls(mcs_map) - 1;
2298 else
2299 idx_limit = -1;
2300
2301 switch (idx_limit) {
2302 case 0: /* fall through */
2303 case 1: /* fall through */
2304 case 2: /* fall through */
2305 case 3: /* fall through */
2306 case 4: /* fall through */
2307 case 5: /* fall through */
2308 case 6: /* fall through */
2309 default:
2310 /* see ath10k_mac_can_set_bitrate_mask() */
2311 WARN_ON(1);
2312 /* fall through */
2313 case -1:
2314 mcs = IEEE80211_VHT_MCS_NOT_SUPPORTED;
2315 break;
2316 case 7:
2317 mcs = IEEE80211_VHT_MCS_SUPPORT_0_7;
2318 break;
2319 case 8:
2320 mcs = IEEE80211_VHT_MCS_SUPPORT_0_8;
2321 break;
2322 case 9:
2323 mcs = IEEE80211_VHT_MCS_SUPPORT_0_9;
2324 break;
2325 }
2326
2327 tx_mcs_set &= ~(0x3 << (nss * 2));
2328 tx_mcs_set |= mcs << (nss * 2);
2329 }
2330
2331 return tx_mcs_set;
2332}
2333
Kalle Valo5e3dd152013-06-12 20:52:10 +03002334static void ath10k_peer_assoc_h_vht(struct ath10k *ar,
Michal Kazior500ff9f2015-03-31 10:26:21 +00002335 struct ieee80211_vif *vif,
Kalle Valo5e3dd152013-06-12 20:52:10 +03002336 struct ieee80211_sta *sta,
2337 struct wmi_peer_assoc_complete_arg *arg)
2338{
2339 const struct ieee80211_sta_vht_cap *vht_cap = &sta->vht_cap;
Michal Kazior45c9abc2015-04-21 20:42:58 +03002340 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kazior500ff9f2015-03-31 10:26:21 +00002341 struct cfg80211_chan_def def;
Michal Kazior45c9abc2015-04-21 20:42:58 +03002342 enum ieee80211_band band;
2343 const u16 *vht_mcs_mask;
Sujith Manoharana24b88b2013-10-07 19:51:57 -07002344 u8 ampdu_factor;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002345
Michal Kazior500ff9f2015-03-31 10:26:21 +00002346 if (WARN_ON(ath10k_mac_vif_chan(vif, &def)))
2347 return;
2348
Kalle Valo5e3dd152013-06-12 20:52:10 +03002349 if (!vht_cap->vht_supported)
2350 return;
2351
Michal Kazior45c9abc2015-04-21 20:42:58 +03002352 band = def.chan->band;
2353 vht_mcs_mask = arvif->bitrate_mask.control[band].vht_mcs;
2354
2355 if (ath10k_peer_assoc_h_vht_masked(vht_mcs_mask))
2356 return;
2357
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002358 arg->peer_flags |= ar->wmi.peer_flags->vht;
Yanbo Lid68bb122015-01-23 08:18:20 +08002359
Michal Kazior500ff9f2015-03-31 10:26:21 +00002360 if (def.chan->band == IEEE80211_BAND_2GHZ)
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002361 arg->peer_flags |= ar->wmi.peer_flags->vht_2g;
Yanbo Lid68bb122015-01-23 08:18:20 +08002362
Kalle Valo5e3dd152013-06-12 20:52:10 +03002363 arg->peer_vht_caps = vht_cap->cap;
2364
Sujith Manoharana24b88b2013-10-07 19:51:57 -07002365 ampdu_factor = (vht_cap->cap &
2366 IEEE80211_VHT_CAP_MAX_A_MPDU_LENGTH_EXPONENT_MASK) >>
2367 IEEE80211_VHT_CAP_MAX_A_MPDU_LENGTH_EXPONENT_SHIFT;
2368
2369 /* Workaround: Some Netgear/Linksys 11ac APs set Rx A-MPDU factor to
2370 * zero in VHT IE. Using it would result in degraded throughput.
2371 * arg->peer_max_mpdu at this point contains HT max_mpdu so keep
2372 * it if VHT max_mpdu is smaller. */
2373 arg->peer_max_mpdu = max(arg->peer_max_mpdu,
2374 (1U << (IEEE80211_HT_MAX_AMPDU_FACTOR +
2375 ampdu_factor)) - 1);
2376
Kalle Valo5e3dd152013-06-12 20:52:10 +03002377 if (sta->bandwidth == IEEE80211_STA_RX_BW_80)
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002378 arg->peer_flags |= ar->wmi.peer_flags->bw80;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002379
2380 arg->peer_vht_rates.rx_max_rate =
2381 __le16_to_cpu(vht_cap->vht_mcs.rx_highest);
2382 arg->peer_vht_rates.rx_mcs_set =
2383 __le16_to_cpu(vht_cap->vht_mcs.rx_mcs_map);
2384 arg->peer_vht_rates.tx_max_rate =
2385 __le16_to_cpu(vht_cap->vht_mcs.tx_highest);
Michal Kazior45c9abc2015-04-21 20:42:58 +03002386 arg->peer_vht_rates.tx_mcs_set = ath10k_peer_assoc_h_vht_limit(
2387 __le16_to_cpu(vht_cap->vht_mcs.tx_mcs_map), vht_mcs_mask);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002388
Michal Kazior7aa7a722014-08-25 12:09:38 +02002389 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vht peer %pM max_mpdu %d flags 0x%x\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03002390 sta->addr, arg->peer_max_mpdu, arg->peer_flags);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002391}
2392
2393static void ath10k_peer_assoc_h_qos(struct ath10k *ar,
Michal Kazior590922a2014-10-21 10:10:29 +03002394 struct ieee80211_vif *vif,
Kalle Valo5e3dd152013-06-12 20:52:10 +03002395 struct ieee80211_sta *sta,
Kalle Valo5e3dd152013-06-12 20:52:10 +03002396 struct wmi_peer_assoc_complete_arg *arg)
2397{
Michal Kazior590922a2014-10-21 10:10:29 +03002398 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
2399
Kalle Valo5e3dd152013-06-12 20:52:10 +03002400 switch (arvif->vdev_type) {
2401 case WMI_VDEV_TYPE_AP:
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002402 if (sta->wme)
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002403 arg->peer_flags |= arvif->ar->wmi.peer_flags->qos;
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002404
2405 if (sta->wme && sta->uapsd_queues) {
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002406 arg->peer_flags |= arvif->ar->wmi.peer_flags->apsd;
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002407 arg->peer_rate_caps |= WMI_RC_UAPSD_FLAG;
2408 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002409 break;
2410 case WMI_VDEV_TYPE_STA:
Michal Kazior590922a2014-10-21 10:10:29 +03002411 if (vif->bss_conf.qos)
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002412 arg->peer_flags |= arvif->ar->wmi.peer_flags->qos;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002413 break;
Janusz Dziedzic627d9842014-12-17 12:29:54 +02002414 case WMI_VDEV_TYPE_IBSS:
2415 if (sta->wme)
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002416 arg->peer_flags |= arvif->ar->wmi.peer_flags->qos;
Janusz Dziedzic627d9842014-12-17 12:29:54 +02002417 break;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002418 default:
2419 break;
2420 }
Janusz Dziedzic627d9842014-12-17 12:29:54 +02002421
2422 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac peer %pM qos %d\n",
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002423 sta->addr, !!(arg->peer_flags &
2424 arvif->ar->wmi.peer_flags->qos));
Kalle Valo5e3dd152013-06-12 20:52:10 +03002425}
2426
Michal Kazior8d7aa6b2015-03-30 09:51:57 +03002427static bool ath10k_mac_sta_has_ofdm_only(struct ieee80211_sta *sta)
Michal Kazior91b12082014-12-12 12:41:35 +01002428{
Michal Kazior8d7aa6b2015-03-30 09:51:57 +03002429 return sta->supp_rates[IEEE80211_BAND_2GHZ] >>
2430 ATH10K_MAC_FIRST_OFDM_RATE_IDX;
Michal Kazior91b12082014-12-12 12:41:35 +01002431}
2432
Kalle Valo5e3dd152013-06-12 20:52:10 +03002433static void ath10k_peer_assoc_h_phymode(struct ath10k *ar,
Michal Kazior590922a2014-10-21 10:10:29 +03002434 struct ieee80211_vif *vif,
Kalle Valo5e3dd152013-06-12 20:52:10 +03002435 struct ieee80211_sta *sta,
2436 struct wmi_peer_assoc_complete_arg *arg)
2437{
Michal Kazior45c9abc2015-04-21 20:42:58 +03002438 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kazior500ff9f2015-03-31 10:26:21 +00002439 struct cfg80211_chan_def def;
Michal Kazior45c9abc2015-04-21 20:42:58 +03002440 enum ieee80211_band band;
2441 const u8 *ht_mcs_mask;
2442 const u16 *vht_mcs_mask;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002443 enum wmi_phy_mode phymode = MODE_UNKNOWN;
2444
Michal Kazior500ff9f2015-03-31 10:26:21 +00002445 if (WARN_ON(ath10k_mac_vif_chan(vif, &def)))
2446 return;
2447
Michal Kazior45c9abc2015-04-21 20:42:58 +03002448 band = def.chan->band;
2449 ht_mcs_mask = arvif->bitrate_mask.control[band].ht_mcs;
2450 vht_mcs_mask = arvif->bitrate_mask.control[band].vht_mcs;
2451
2452 switch (band) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03002453 case IEEE80211_BAND_2GHZ:
Michal Kazior45c9abc2015-04-21 20:42:58 +03002454 if (sta->vht_cap.vht_supported &&
2455 !ath10k_peer_assoc_h_vht_masked(vht_mcs_mask)) {
Yanbo Lid68bb122015-01-23 08:18:20 +08002456 if (sta->bandwidth == IEEE80211_STA_RX_BW_40)
2457 phymode = MODE_11AC_VHT40;
2458 else
2459 phymode = MODE_11AC_VHT20;
Michal Kazior45c9abc2015-04-21 20:42:58 +03002460 } else if (sta->ht_cap.ht_supported &&
2461 !ath10k_peer_assoc_h_ht_masked(ht_mcs_mask)) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03002462 if (sta->bandwidth == IEEE80211_STA_RX_BW_40)
2463 phymode = MODE_11NG_HT40;
2464 else
2465 phymode = MODE_11NG_HT20;
Michal Kazior8d7aa6b2015-03-30 09:51:57 +03002466 } else if (ath10k_mac_sta_has_ofdm_only(sta)) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03002467 phymode = MODE_11G;
Michal Kazior91b12082014-12-12 12:41:35 +01002468 } else {
2469 phymode = MODE_11B;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002470 }
2471
2472 break;
2473 case IEEE80211_BAND_5GHZ:
Sujith Manoharan7cc45e92013-09-08 18:19:55 +03002474 /*
2475 * Check VHT first.
2476 */
Michal Kazior45c9abc2015-04-21 20:42:58 +03002477 if (sta->vht_cap.vht_supported &&
2478 !ath10k_peer_assoc_h_vht_masked(vht_mcs_mask)) {
Sujith Manoharan7cc45e92013-09-08 18:19:55 +03002479 if (sta->bandwidth == IEEE80211_STA_RX_BW_80)
2480 phymode = MODE_11AC_VHT80;
2481 else if (sta->bandwidth == IEEE80211_STA_RX_BW_40)
2482 phymode = MODE_11AC_VHT40;
2483 else if (sta->bandwidth == IEEE80211_STA_RX_BW_20)
2484 phymode = MODE_11AC_VHT20;
Michal Kazior45c9abc2015-04-21 20:42:58 +03002485 } else if (sta->ht_cap.ht_supported &&
2486 !ath10k_peer_assoc_h_ht_masked(ht_mcs_mask)) {
2487 if (sta->bandwidth >= IEEE80211_STA_RX_BW_40)
Kalle Valo5e3dd152013-06-12 20:52:10 +03002488 phymode = MODE_11NA_HT40;
2489 else
2490 phymode = MODE_11NA_HT20;
2491 } else {
2492 phymode = MODE_11A;
2493 }
2494
2495 break;
2496 default:
2497 break;
2498 }
2499
Michal Kazior7aa7a722014-08-25 12:09:38 +02002500 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac peer %pM phymode %s\n",
Kalle Valo38a1d472013-09-08 17:56:14 +03002501 sta->addr, ath10k_wmi_phymode_str(phymode));
Kalle Valo60c3daa2013-09-08 17:56:07 +03002502
Kalle Valo5e3dd152013-06-12 20:52:10 +03002503 arg->peer_phymode = phymode;
2504 WARN_ON(phymode == MODE_UNKNOWN);
2505}
2506
Kalle Valob9ada652013-10-16 15:44:46 +03002507static int ath10k_peer_assoc_prepare(struct ath10k *ar,
Michal Kazior590922a2014-10-21 10:10:29 +03002508 struct ieee80211_vif *vif,
Kalle Valob9ada652013-10-16 15:44:46 +03002509 struct ieee80211_sta *sta,
Kalle Valob9ada652013-10-16 15:44:46 +03002510 struct wmi_peer_assoc_complete_arg *arg)
Kalle Valo5e3dd152013-06-12 20:52:10 +03002511{
Michal Kazior548db542013-07-05 16:15:15 +03002512 lockdep_assert_held(&ar->conf_mutex);
2513
Kalle Valob9ada652013-10-16 15:44:46 +03002514 memset(arg, 0, sizeof(*arg));
Kalle Valo5e3dd152013-06-12 20:52:10 +03002515
Michal Kazior590922a2014-10-21 10:10:29 +03002516 ath10k_peer_assoc_h_basic(ar, vif, sta, arg);
Tamizh chelvam90eceb32015-10-29 14:27:42 +02002517 ath10k_peer_assoc_h_crypto(ar, vif, sta, arg);
Michal Kazior500ff9f2015-03-31 10:26:21 +00002518 ath10k_peer_assoc_h_rates(ar, vif, sta, arg);
Michal Kazior45c9abc2015-04-21 20:42:58 +03002519 ath10k_peer_assoc_h_ht(ar, vif, sta, arg);
Michal Kazior500ff9f2015-03-31 10:26:21 +00002520 ath10k_peer_assoc_h_vht(ar, vif, sta, arg);
Michal Kazior590922a2014-10-21 10:10:29 +03002521 ath10k_peer_assoc_h_qos(ar, vif, sta, arg);
2522 ath10k_peer_assoc_h_phymode(ar, vif, sta, arg);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002523
Kalle Valob9ada652013-10-16 15:44:46 +03002524 return 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002525}
2526
Michal Kazior90046f52014-02-14 14:45:51 +01002527static const u32 ath10k_smps_map[] = {
2528 [WLAN_HT_CAP_SM_PS_STATIC] = WMI_PEER_SMPS_STATIC,
2529 [WLAN_HT_CAP_SM_PS_DYNAMIC] = WMI_PEER_SMPS_DYNAMIC,
2530 [WLAN_HT_CAP_SM_PS_INVALID] = WMI_PEER_SMPS_PS_NONE,
2531 [WLAN_HT_CAP_SM_PS_DISABLED] = WMI_PEER_SMPS_PS_NONE,
2532};
2533
2534static int ath10k_setup_peer_smps(struct ath10k *ar, struct ath10k_vif *arvif,
2535 const u8 *addr,
2536 const struct ieee80211_sta_ht_cap *ht_cap)
2537{
2538 int smps;
2539
2540 if (!ht_cap->ht_supported)
2541 return 0;
2542
2543 smps = ht_cap->cap & IEEE80211_HT_CAP_SM_PS;
2544 smps >>= IEEE80211_HT_CAP_SM_PS_SHIFT;
2545
2546 if (smps >= ARRAY_SIZE(ath10k_smps_map))
2547 return -EINVAL;
2548
2549 return ath10k_wmi_peer_set_param(ar, arvif->vdev_id, addr,
2550 WMI_PEER_SMPS_STATE,
2551 ath10k_smps_map[smps]);
2552}
2553
Michal Kazior139e1702015-02-15 16:50:42 +02002554static int ath10k_mac_vif_recalc_txbf(struct ath10k *ar,
2555 struct ieee80211_vif *vif,
2556 struct ieee80211_sta_vht_cap vht_cap)
2557{
2558 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
2559 int ret;
2560 u32 param;
2561 u32 value;
2562
Vivek Natarajan08e75ea2015-08-04 10:45:11 +05302563 if (ath10k_wmi_get_txbf_conf_scheme(ar) != WMI_TXBF_CONF_AFTER_ASSOC)
2564 return 0;
2565
Michal Kazior139e1702015-02-15 16:50:42 +02002566 if (!(ar->vht_cap_info &
2567 (IEEE80211_VHT_CAP_SU_BEAMFORMEE_CAPABLE |
2568 IEEE80211_VHT_CAP_MU_BEAMFORMEE_CAPABLE |
2569 IEEE80211_VHT_CAP_SU_BEAMFORMER_CAPABLE |
2570 IEEE80211_VHT_CAP_MU_BEAMFORMER_CAPABLE)))
2571 return 0;
2572
2573 param = ar->wmi.vdev_param->txbf;
2574 value = 0;
2575
2576 if (WARN_ON(param == WMI_VDEV_PARAM_UNSUPPORTED))
2577 return 0;
2578
2579 /* The following logic is correct. If a remote STA advertises support
2580 * for being a beamformer then we should enable us being a beamformee.
2581 */
2582
2583 if (ar->vht_cap_info &
2584 (IEEE80211_VHT_CAP_SU_BEAMFORMEE_CAPABLE |
2585 IEEE80211_VHT_CAP_MU_BEAMFORMEE_CAPABLE)) {
2586 if (vht_cap.cap & IEEE80211_VHT_CAP_SU_BEAMFORMER_CAPABLE)
2587 value |= WMI_VDEV_PARAM_TXBF_SU_TX_BFEE;
2588
2589 if (vht_cap.cap & IEEE80211_VHT_CAP_MU_BEAMFORMER_CAPABLE)
2590 value |= WMI_VDEV_PARAM_TXBF_MU_TX_BFEE;
2591 }
2592
2593 if (ar->vht_cap_info &
2594 (IEEE80211_VHT_CAP_SU_BEAMFORMER_CAPABLE |
2595 IEEE80211_VHT_CAP_MU_BEAMFORMER_CAPABLE)) {
2596 if (vht_cap.cap & IEEE80211_VHT_CAP_SU_BEAMFORMEE_CAPABLE)
2597 value |= WMI_VDEV_PARAM_TXBF_SU_TX_BFER;
2598
2599 if (vht_cap.cap & IEEE80211_VHT_CAP_MU_BEAMFORMEE_CAPABLE)
2600 value |= WMI_VDEV_PARAM_TXBF_MU_TX_BFER;
2601 }
2602
2603 if (value & WMI_VDEV_PARAM_TXBF_MU_TX_BFEE)
2604 value |= WMI_VDEV_PARAM_TXBF_SU_TX_BFEE;
2605
2606 if (value & WMI_VDEV_PARAM_TXBF_MU_TX_BFER)
2607 value |= WMI_VDEV_PARAM_TXBF_SU_TX_BFER;
2608
2609 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, param, value);
2610 if (ret) {
2611 ath10k_warn(ar, "failed to submit vdev param txbf 0x%x: %d\n",
2612 value, ret);
2613 return ret;
2614 }
2615
2616 return 0;
2617}
2618
Kalle Valo5e3dd152013-06-12 20:52:10 +03002619/* can be called only in mac80211 callbacks due to `key_count` usage */
2620static void ath10k_bss_assoc(struct ieee80211_hw *hw,
2621 struct ieee80211_vif *vif,
2622 struct ieee80211_bss_conf *bss_conf)
2623{
2624 struct ath10k *ar = hw->priv;
2625 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kazior90046f52014-02-14 14:45:51 +01002626 struct ieee80211_sta_ht_cap ht_cap;
Michal Kazior139e1702015-02-15 16:50:42 +02002627 struct ieee80211_sta_vht_cap vht_cap;
Kalle Valob9ada652013-10-16 15:44:46 +03002628 struct wmi_peer_assoc_complete_arg peer_arg;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002629 struct ieee80211_sta *ap_sta;
2630 int ret;
2631
Michal Kazior548db542013-07-05 16:15:15 +03002632 lockdep_assert_held(&ar->conf_mutex);
2633
Michal Kazior077efc82014-10-21 10:10:29 +03002634 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %i assoc bssid %pM aid %d\n",
2635 arvif->vdev_id, arvif->bssid, arvif->aid);
2636
Kalle Valo5e3dd152013-06-12 20:52:10 +03002637 rcu_read_lock();
2638
2639 ap_sta = ieee80211_find_sta(vif, bss_conf->bssid);
2640 if (!ap_sta) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002641 ath10k_warn(ar, "failed to find station entry for bss %pM vdev %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02002642 bss_conf->bssid, arvif->vdev_id);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002643 rcu_read_unlock();
2644 return;
2645 }
2646
Michal Kazior90046f52014-02-14 14:45:51 +01002647 /* ap_sta must be accessed only within rcu section which must be left
2648 * before calling ath10k_setup_peer_smps() which might sleep. */
2649 ht_cap = ap_sta->ht_cap;
Michal Kazior139e1702015-02-15 16:50:42 +02002650 vht_cap = ap_sta->vht_cap;
Michal Kazior90046f52014-02-14 14:45:51 +01002651
Michal Kazior590922a2014-10-21 10:10:29 +03002652 ret = ath10k_peer_assoc_prepare(ar, vif, ap_sta, &peer_arg);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002653 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002654 ath10k_warn(ar, "failed to prepare peer assoc for %pM vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02002655 bss_conf->bssid, arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002656 rcu_read_unlock();
2657 return;
2658 }
2659
2660 rcu_read_unlock();
2661
Kalle Valob9ada652013-10-16 15:44:46 +03002662 ret = ath10k_wmi_peer_assoc(ar, &peer_arg);
2663 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002664 ath10k_warn(ar, "failed to run peer assoc for %pM vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02002665 bss_conf->bssid, arvif->vdev_id, ret);
Kalle Valob9ada652013-10-16 15:44:46 +03002666 return;
2667 }
2668
Michal Kazior90046f52014-02-14 14:45:51 +01002669 ret = ath10k_setup_peer_smps(ar, arvif, bss_conf->bssid, &ht_cap);
2670 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002671 ath10k_warn(ar, "failed to setup peer SMPS for vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02002672 arvif->vdev_id, ret);
Michal Kazior90046f52014-02-14 14:45:51 +01002673 return;
2674 }
2675
Michal Kazior139e1702015-02-15 16:50:42 +02002676 ret = ath10k_mac_vif_recalc_txbf(ar, vif, vht_cap);
2677 if (ret) {
2678 ath10k_warn(ar, "failed to recalc txbf for vdev %i on bss %pM: %d\n",
2679 arvif->vdev_id, bss_conf->bssid, ret);
2680 return;
2681 }
2682
Michal Kazior7aa7a722014-08-25 12:09:38 +02002683 ath10k_dbg(ar, ATH10K_DBG_MAC,
Kalle Valo60c3daa2013-09-08 17:56:07 +03002684 "mac vdev %d up (associated) bssid %pM aid %d\n",
2685 arvif->vdev_id, bss_conf->bssid, bss_conf->aid);
2686
Michal Kazior077efc82014-10-21 10:10:29 +03002687 WARN_ON(arvif->is_up);
2688
Michal Kaziorc930f742014-01-23 11:38:25 +01002689 arvif->aid = bss_conf->aid;
Kalle Valob25f32c2014-09-14 12:50:49 +03002690 ether_addr_copy(arvif->bssid, bss_conf->bssid);
Michal Kaziorc930f742014-01-23 11:38:25 +01002691
2692 ret = ath10k_wmi_vdev_up(ar, arvif->vdev_id, arvif->aid, arvif->bssid);
2693 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002694 ath10k_warn(ar, "failed to set vdev %d up: %d\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03002695 arvif->vdev_id, ret);
Michal Kaziorc930f742014-01-23 11:38:25 +01002696 return;
2697 }
2698
2699 arvif->is_up = true;
Michal Kazior0a987fb2015-02-13 13:30:15 +01002700
2701 /* Workaround: Some firmware revisions (tested with qca6174
2702 * WLAN.RM.2.0-00073) have buggy powersave state machine and must be
2703 * poked with peer param command.
2704 */
2705 ret = ath10k_wmi_peer_set_param(ar, arvif->vdev_id, arvif->bssid,
2706 WMI_PEER_DUMMY_VAR, 1);
2707 if (ret) {
2708 ath10k_warn(ar, "failed to poke peer %pM param for ps workaround on vdev %i: %d\n",
2709 arvif->bssid, arvif->vdev_id, ret);
2710 return;
2711 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002712}
2713
Kalle Valo5e3dd152013-06-12 20:52:10 +03002714static void ath10k_bss_disassoc(struct ieee80211_hw *hw,
2715 struct ieee80211_vif *vif)
2716{
2717 struct ath10k *ar = hw->priv;
2718 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kazior139e1702015-02-15 16:50:42 +02002719 struct ieee80211_sta_vht_cap vht_cap = {};
Kalle Valo5e3dd152013-06-12 20:52:10 +03002720 int ret;
2721
Michal Kazior548db542013-07-05 16:15:15 +03002722 lockdep_assert_held(&ar->conf_mutex);
2723
Michal Kazior077efc82014-10-21 10:10:29 +03002724 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %i disassoc bssid %pM\n",
2725 arvif->vdev_id, arvif->bssid);
Kalle Valo60c3daa2013-09-08 17:56:07 +03002726
Kalle Valo5e3dd152013-06-12 20:52:10 +03002727 ret = ath10k_wmi_vdev_down(ar, arvif->vdev_id);
Michal Kazior077efc82014-10-21 10:10:29 +03002728 if (ret)
2729 ath10k_warn(ar, "faield to down vdev %i: %d\n",
2730 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002731
SenthilKumar Jegadeesan627613f2015-01-29 13:50:38 +02002732 arvif->def_wep_key_idx = -1;
2733
Michal Kazior139e1702015-02-15 16:50:42 +02002734 ret = ath10k_mac_vif_recalc_txbf(ar, vif, vht_cap);
2735 if (ret) {
2736 ath10k_warn(ar, "failed to recalc txbf for vdev %i: %d\n",
2737 arvif->vdev_id, ret);
2738 return;
2739 }
2740
Michal Kaziorc930f742014-01-23 11:38:25 +01002741 arvif->is_up = false;
Michal Kaziorcc9904e2015-03-10 16:22:01 +02002742
2743 cancel_delayed_work_sync(&arvif->connection_loss_work);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002744}
2745
Michal Kazior590922a2014-10-21 10:10:29 +03002746static int ath10k_station_assoc(struct ath10k *ar,
2747 struct ieee80211_vif *vif,
2748 struct ieee80211_sta *sta,
2749 bool reassoc)
Kalle Valo5e3dd152013-06-12 20:52:10 +03002750{
Michal Kazior590922a2014-10-21 10:10:29 +03002751 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Kalle Valob9ada652013-10-16 15:44:46 +03002752 struct wmi_peer_assoc_complete_arg peer_arg;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002753 int ret = 0;
2754
Michal Kazior548db542013-07-05 16:15:15 +03002755 lockdep_assert_held(&ar->conf_mutex);
2756
Michal Kazior590922a2014-10-21 10:10:29 +03002757 ret = ath10k_peer_assoc_prepare(ar, vif, sta, &peer_arg);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002758 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002759 ath10k_warn(ar, "failed to prepare WMI peer assoc for %pM vdev %i: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02002760 sta->addr, arvif->vdev_id, ret);
Kalle Valob9ada652013-10-16 15:44:46 +03002761 return ret;
2762 }
2763
2764 ret = ath10k_wmi_peer_assoc(ar, &peer_arg);
2765 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002766 ath10k_warn(ar, "failed to run peer assoc for STA %pM vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02002767 sta->addr, arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002768 return ret;
2769 }
2770
Michal Kaziorb1ecde32014-10-21 10:10:29 +03002771 /* Re-assoc is run only to update supported rates for given station. It
2772 * doesn't make much sense to reconfigure the peer completely.
2773 */
2774 if (!reassoc) {
2775 ret = ath10k_setup_peer_smps(ar, arvif, sta->addr,
2776 &sta->ht_cap);
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02002777 if (ret) {
Michal Kaziorb1ecde32014-10-21 10:10:29 +03002778 ath10k_warn(ar, "failed to setup peer SMPS for vdev %d: %d\n",
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02002779 arvif->vdev_id, ret);
2780 return ret;
2781 }
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02002782
Michal Kaziorb1ecde32014-10-21 10:10:29 +03002783 ret = ath10k_peer_assoc_qos_ap(ar, arvif, sta);
2784 if (ret) {
2785 ath10k_warn(ar, "failed to set qos params for STA %pM for vdev %i: %d\n",
2786 sta->addr, arvif->vdev_id, ret);
2787 return ret;
2788 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002789
Michal Kaziorb1ecde32014-10-21 10:10:29 +03002790 if (!sta->wme) {
2791 arvif->num_legacy_stations++;
2792 ret = ath10k_recalc_rtscts_prot(arvif);
2793 if (ret) {
2794 ath10k_warn(ar, "failed to recalculate rts/cts prot for vdev %d: %d\n",
2795 arvif->vdev_id, ret);
2796 return ret;
2797 }
2798 }
2799
SenthilKumar Jegadeesan627613f2015-01-29 13:50:38 +02002800 /* Plumb cached keys only for static WEP */
2801 if (arvif->def_wep_key_idx != -1) {
2802 ret = ath10k_install_peer_wep_keys(arvif, sta->addr);
2803 if (ret) {
2804 ath10k_warn(ar, "failed to install peer wep keys for vdev %i: %d\n",
2805 arvif->vdev_id, ret);
2806 return ret;
2807 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002808 }
2809 }
2810
Kalle Valo5e3dd152013-06-12 20:52:10 +03002811 return ret;
2812}
2813
Michal Kazior590922a2014-10-21 10:10:29 +03002814static int ath10k_station_disassoc(struct ath10k *ar,
2815 struct ieee80211_vif *vif,
Kalle Valo5e3dd152013-06-12 20:52:10 +03002816 struct ieee80211_sta *sta)
2817{
Michal Kazior590922a2014-10-21 10:10:29 +03002818 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002819 int ret = 0;
2820
2821 lockdep_assert_held(&ar->conf_mutex);
2822
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02002823 if (!sta->wme) {
2824 arvif->num_legacy_stations--;
2825 ret = ath10k_recalc_rtscts_prot(arvif);
2826 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002827 ath10k_warn(ar, "failed to recalculate rts/cts prot for vdev %d: %d\n",
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02002828 arvif->vdev_id, ret);
2829 return ret;
2830 }
2831 }
2832
Kalle Valo5e3dd152013-06-12 20:52:10 +03002833 ret = ath10k_clear_peer_keys(arvif, sta->addr);
2834 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002835 ath10k_warn(ar, "failed to clear all peer wep keys for vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02002836 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002837 return ret;
2838 }
2839
2840 return ret;
2841}
2842
2843/**************/
2844/* Regulatory */
2845/**************/
2846
2847static int ath10k_update_channel_list(struct ath10k *ar)
2848{
2849 struct ieee80211_hw *hw = ar->hw;
2850 struct ieee80211_supported_band **bands;
2851 enum ieee80211_band band;
2852 struct ieee80211_channel *channel;
2853 struct wmi_scan_chan_list_arg arg = {0};
2854 struct wmi_channel_arg *ch;
2855 bool passive;
2856 int len;
2857 int ret;
2858 int i;
2859
Michal Kazior548db542013-07-05 16:15:15 +03002860 lockdep_assert_held(&ar->conf_mutex);
2861
Kalle Valo5e3dd152013-06-12 20:52:10 +03002862 bands = hw->wiphy->bands;
2863 for (band = 0; band < IEEE80211_NUM_BANDS; band++) {
2864 if (!bands[band])
2865 continue;
2866
2867 for (i = 0; i < bands[band]->n_channels; i++) {
2868 if (bands[band]->channels[i].flags &
2869 IEEE80211_CHAN_DISABLED)
2870 continue;
2871
2872 arg.n_channels++;
2873 }
2874 }
2875
2876 len = sizeof(struct wmi_channel_arg) * arg.n_channels;
2877 arg.channels = kzalloc(len, GFP_KERNEL);
2878 if (!arg.channels)
2879 return -ENOMEM;
2880
2881 ch = arg.channels;
2882 for (band = 0; band < IEEE80211_NUM_BANDS; band++) {
2883 if (!bands[band])
2884 continue;
2885
2886 for (i = 0; i < bands[band]->n_channels; i++) {
2887 channel = &bands[band]->channels[i];
2888
2889 if (channel->flags & IEEE80211_CHAN_DISABLED)
2890 continue;
2891
2892 ch->allow_ht = true;
2893
2894 /* FIXME: when should we really allow VHT? */
2895 ch->allow_vht = true;
2896
2897 ch->allow_ibss =
Luis R. Rodriguez8fe02e12013-10-21 19:22:25 +02002898 !(channel->flags & IEEE80211_CHAN_NO_IR);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002899
2900 ch->ht40plus =
2901 !(channel->flags & IEEE80211_CHAN_NO_HT40PLUS);
2902
Marek Puzyniake8a50f82013-11-20 09:59:47 +02002903 ch->chan_radar =
2904 !!(channel->flags & IEEE80211_CHAN_RADAR);
2905
Luis R. Rodriguez8fe02e12013-10-21 19:22:25 +02002906 passive = channel->flags & IEEE80211_CHAN_NO_IR;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002907 ch->passive = passive;
2908
2909 ch->freq = channel->center_freq;
Michal Kazior2d667212014-09-18 15:21:21 +02002910 ch->band_center_freq1 = channel->center_freq;
Michal Kazior89c5c842013-10-23 04:02:13 -07002911 ch->min_power = 0;
Michal Kazior02256932013-10-23 04:02:14 -07002912 ch->max_power = channel->max_power * 2;
2913 ch->max_reg_power = channel->max_reg_power * 2;
2914 ch->max_antenna_gain = channel->max_antenna_gain * 2;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002915 ch->reg_class_id = 0; /* FIXME */
2916
2917 /* FIXME: why use only legacy modes, why not any
2918 * HT/VHT modes? Would that even make any
2919 * difference? */
2920 if (channel->band == IEEE80211_BAND_2GHZ)
2921 ch->mode = MODE_11G;
2922 else
2923 ch->mode = MODE_11A;
2924
2925 if (WARN_ON_ONCE(ch->mode == MODE_UNKNOWN))
2926 continue;
2927
Michal Kazior7aa7a722014-08-25 12:09:38 +02002928 ath10k_dbg(ar, ATH10K_DBG_WMI,
Kalle Valo60c3daa2013-09-08 17:56:07 +03002929 "mac channel [%zd/%d] freq %d maxpower %d regpower %d antenna %d mode %d\n",
2930 ch - arg.channels, arg.n_channels,
Kalle Valo5e3dd152013-06-12 20:52:10 +03002931 ch->freq, ch->max_power, ch->max_reg_power,
2932 ch->max_antenna_gain, ch->mode);
2933
2934 ch++;
2935 }
2936 }
2937
2938 ret = ath10k_wmi_scan_chan_list(ar, &arg);
2939 kfree(arg.channels);
2940
2941 return ret;
2942}
2943
Marek Puzyniak821af6a2014-03-21 17:46:57 +02002944static enum wmi_dfs_region
2945ath10k_mac_get_dfs_region(enum nl80211_dfs_regions dfs_region)
2946{
2947 switch (dfs_region) {
2948 case NL80211_DFS_UNSET:
2949 return WMI_UNINIT_DFS_DOMAIN;
2950 case NL80211_DFS_FCC:
2951 return WMI_FCC_DFS_DOMAIN;
2952 case NL80211_DFS_ETSI:
2953 return WMI_ETSI_DFS_DOMAIN;
2954 case NL80211_DFS_JP:
2955 return WMI_MKK4_DFS_DOMAIN;
2956 }
2957 return WMI_UNINIT_DFS_DOMAIN;
2958}
2959
Michal Kaziorf7843d72013-07-16 09:38:52 +02002960static void ath10k_regd_update(struct ath10k *ar)
Kalle Valo5e3dd152013-06-12 20:52:10 +03002961{
Kalle Valo5e3dd152013-06-12 20:52:10 +03002962 struct reg_dmn_pair_mapping *regpair;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002963 int ret;
Marek Puzyniak821af6a2014-03-21 17:46:57 +02002964 enum wmi_dfs_region wmi_dfs_reg;
2965 enum nl80211_dfs_regions nl_dfs_reg;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002966
Michal Kaziorf7843d72013-07-16 09:38:52 +02002967 lockdep_assert_held(&ar->conf_mutex);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002968
2969 ret = ath10k_update_channel_list(ar);
2970 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02002971 ath10k_warn(ar, "failed to update channel list: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002972
2973 regpair = ar->ath_common.regulatory.regpair;
Michal Kaziorf7843d72013-07-16 09:38:52 +02002974
Marek Puzyniak821af6a2014-03-21 17:46:57 +02002975 if (config_enabled(CONFIG_ATH10K_DFS_CERTIFIED) && ar->dfs_detector) {
2976 nl_dfs_reg = ar->dfs_detector->region;
2977 wmi_dfs_reg = ath10k_mac_get_dfs_region(nl_dfs_reg);
2978 } else {
2979 wmi_dfs_reg = WMI_UNINIT_DFS_DOMAIN;
2980 }
2981
Kalle Valo5e3dd152013-06-12 20:52:10 +03002982 /* Target allows setting up per-band regdomain but ath_common provides
2983 * a combined one only */
2984 ret = ath10k_wmi_pdev_set_regdomain(ar,
Kalle Valoef8c0012014-02-13 18:13:12 +02002985 regpair->reg_domain,
2986 regpair->reg_domain, /* 2ghz */
2987 regpair->reg_domain, /* 5ghz */
Kalle Valo5e3dd152013-06-12 20:52:10 +03002988 regpair->reg_2ghz_ctl,
Marek Puzyniak821af6a2014-03-21 17:46:57 +02002989 regpair->reg_5ghz_ctl,
2990 wmi_dfs_reg);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002991 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02002992 ath10k_warn(ar, "failed to set pdev regdomain: %d\n", ret);
Michal Kaziorf7843d72013-07-16 09:38:52 +02002993}
Michal Kazior548db542013-07-05 16:15:15 +03002994
Michal Kaziorf7843d72013-07-16 09:38:52 +02002995static void ath10k_reg_notifier(struct wiphy *wiphy,
2996 struct regulatory_request *request)
2997{
2998 struct ieee80211_hw *hw = wiphy_to_ieee80211_hw(wiphy);
2999 struct ath10k *ar = hw->priv;
Janusz Dziedzic9702c682013-11-20 09:59:41 +02003000 bool result;
Michal Kaziorf7843d72013-07-16 09:38:52 +02003001
3002 ath_reg_notifier_apply(wiphy, request, &ar->ath_common.regulatory);
3003
Janusz Dziedzic9702c682013-11-20 09:59:41 +02003004 if (config_enabled(CONFIG_ATH10K_DFS_CERTIFIED) && ar->dfs_detector) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003005 ath10k_dbg(ar, ATH10K_DBG_REGULATORY, "dfs region 0x%x\n",
Janusz Dziedzic9702c682013-11-20 09:59:41 +02003006 request->dfs_region);
3007 result = ar->dfs_detector->set_dfs_domain(ar->dfs_detector,
3008 request->dfs_region);
3009 if (!result)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003010 ath10k_warn(ar, "DFS region 0x%X not supported, will trigger radar for every pulse\n",
Janusz Dziedzic9702c682013-11-20 09:59:41 +02003011 request->dfs_region);
3012 }
3013
Michal Kaziorf7843d72013-07-16 09:38:52 +02003014 mutex_lock(&ar->conf_mutex);
3015 if (ar->state == ATH10K_STATE_ON)
3016 ath10k_regd_update(ar);
Michal Kazior548db542013-07-05 16:15:15 +03003017 mutex_unlock(&ar->conf_mutex);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003018}
3019
3020/***************/
3021/* TX handlers */
3022/***************/
3023
Michal Kaziora30c7d02016-03-06 16:14:23 +02003024enum ath10k_mac_tx_path {
3025 ATH10K_MAC_TX_HTT,
3026 ATH10K_MAC_TX_HTT_MGMT,
3027 ATH10K_MAC_TX_WMI_MGMT,
3028 ATH10K_MAC_TX_UNKNOWN,
3029};
3030
Michal Kazior96d828d2015-03-31 10:26:23 +00003031void ath10k_mac_tx_lock(struct ath10k *ar, int reason)
3032{
3033 lockdep_assert_held(&ar->htt.tx_lock);
3034
3035 WARN_ON(reason >= ATH10K_TX_PAUSE_MAX);
3036 ar->tx_paused |= BIT(reason);
3037 ieee80211_stop_queues(ar->hw);
3038}
3039
3040static void ath10k_mac_tx_unlock_iter(void *data, u8 *mac,
3041 struct ieee80211_vif *vif)
3042{
3043 struct ath10k *ar = data;
3044 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
3045
3046 if (arvif->tx_paused)
3047 return;
3048
3049 ieee80211_wake_queue(ar->hw, arvif->vdev_id);
3050}
3051
3052void ath10k_mac_tx_unlock(struct ath10k *ar, int reason)
3053{
3054 lockdep_assert_held(&ar->htt.tx_lock);
3055
3056 WARN_ON(reason >= ATH10K_TX_PAUSE_MAX);
3057 ar->tx_paused &= ~BIT(reason);
3058
3059 if (ar->tx_paused)
3060 return;
3061
3062 ieee80211_iterate_active_interfaces_atomic(ar->hw,
3063 IEEE80211_IFACE_ITER_RESUME_ALL,
3064 ath10k_mac_tx_unlock_iter,
3065 ar);
Michal Kazior3a73d1a2015-08-06 14:46:54 +02003066
3067 ieee80211_wake_queue(ar->hw, ar->hw->offchannel_tx_hw_queue);
Michal Kazior96d828d2015-03-31 10:26:23 +00003068}
3069
3070void ath10k_mac_vif_tx_lock(struct ath10k_vif *arvif, int reason)
3071{
3072 struct ath10k *ar = arvif->ar;
3073
3074 lockdep_assert_held(&ar->htt.tx_lock);
3075
3076 WARN_ON(reason >= BITS_PER_LONG);
3077 arvif->tx_paused |= BIT(reason);
3078 ieee80211_stop_queue(ar->hw, arvif->vdev_id);
3079}
3080
3081void ath10k_mac_vif_tx_unlock(struct ath10k_vif *arvif, int reason)
3082{
3083 struct ath10k *ar = arvif->ar;
3084
3085 lockdep_assert_held(&ar->htt.tx_lock);
3086
3087 WARN_ON(reason >= BITS_PER_LONG);
3088 arvif->tx_paused &= ~BIT(reason);
3089
3090 if (ar->tx_paused)
3091 return;
3092
3093 if (arvif->tx_paused)
3094 return;
3095
3096 ieee80211_wake_queue(ar->hw, arvif->vdev_id);
3097}
3098
Michal Kaziorb4aa5392015-03-31 10:26:24 +00003099static void ath10k_mac_vif_handle_tx_pause(struct ath10k_vif *arvif,
3100 enum wmi_tlv_tx_pause_id pause_id,
3101 enum wmi_tlv_tx_pause_action action)
3102{
3103 struct ath10k *ar = arvif->ar;
3104
3105 lockdep_assert_held(&ar->htt.tx_lock);
3106
Michal Kazioracd0b272015-07-09 13:08:38 +02003107 switch (action) {
3108 case WMI_TLV_TX_PAUSE_ACTION_STOP:
3109 ath10k_mac_vif_tx_lock(arvif, pause_id);
Michal Kaziorb4aa5392015-03-31 10:26:24 +00003110 break;
Michal Kazioracd0b272015-07-09 13:08:38 +02003111 case WMI_TLV_TX_PAUSE_ACTION_WAKE:
3112 ath10k_mac_vif_tx_unlock(arvif, pause_id);
3113 break;
Michal Kaziorb4aa5392015-03-31 10:26:24 +00003114 default:
Michal Kazioracd0b272015-07-09 13:08:38 +02003115 ath10k_warn(ar, "received unknown tx pause action %d on vdev %i, ignoring\n",
3116 action, arvif->vdev_id);
Michal Kaziorb4aa5392015-03-31 10:26:24 +00003117 break;
3118 }
3119}
3120
3121struct ath10k_mac_tx_pause {
3122 u32 vdev_id;
3123 enum wmi_tlv_tx_pause_id pause_id;
3124 enum wmi_tlv_tx_pause_action action;
3125};
3126
3127static void ath10k_mac_handle_tx_pause_iter(void *data, u8 *mac,
3128 struct ieee80211_vif *vif)
3129{
3130 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
3131 struct ath10k_mac_tx_pause *arg = data;
3132
Michal Kazioracd0b272015-07-09 13:08:38 +02003133 if (arvif->vdev_id != arg->vdev_id)
3134 return;
3135
Michal Kaziorb4aa5392015-03-31 10:26:24 +00003136 ath10k_mac_vif_handle_tx_pause(arvif, arg->pause_id, arg->action);
3137}
3138
Michal Kazioracd0b272015-07-09 13:08:38 +02003139void ath10k_mac_handle_tx_pause_vdev(struct ath10k *ar, u32 vdev_id,
3140 enum wmi_tlv_tx_pause_id pause_id,
3141 enum wmi_tlv_tx_pause_action action)
Michal Kaziorb4aa5392015-03-31 10:26:24 +00003142{
3143 struct ath10k_mac_tx_pause arg = {
3144 .vdev_id = vdev_id,
3145 .pause_id = pause_id,
3146 .action = action,
3147 };
3148
3149 spin_lock_bh(&ar->htt.tx_lock);
3150 ieee80211_iterate_active_interfaces_atomic(ar->hw,
3151 IEEE80211_IFACE_ITER_RESUME_ALL,
3152 ath10k_mac_handle_tx_pause_iter,
3153 &arg);
3154 spin_unlock_bh(&ar->htt.tx_lock);
3155}
3156
Michal Kaziord740d8f2015-03-30 09:51:51 +03003157static enum ath10k_hw_txrx_mode
Michal Kazior6a2636d2015-11-18 06:59:16 +01003158ath10k_mac_tx_h_get_txmode(struct ath10k *ar,
3159 struct ieee80211_vif *vif,
3160 struct ieee80211_sta *sta,
3161 struct sk_buff *skb)
Michal Kaziord740d8f2015-03-30 09:51:51 +03003162{
3163 const struct ieee80211_hdr *hdr = (void *)skb->data;
3164 __le16 fc = hdr->frame_control;
3165
3166 if (!vif || vif->type == NL80211_IFTYPE_MONITOR)
3167 return ATH10K_HW_TXRX_RAW;
3168
3169 if (ieee80211_is_mgmt(fc))
3170 return ATH10K_HW_TXRX_MGMT;
3171
3172 /* Workaround:
3173 *
3174 * NullFunc frames are mostly used to ping if a client or AP are still
3175 * reachable and responsive. This implies tx status reports must be
3176 * accurate - otherwise either mac80211 or userspace (e.g. hostapd) can
3177 * come to a conclusion that the other end disappeared and tear down
3178 * BSS connection or it can never disconnect from BSS/client (which is
3179 * the case).
3180 *
3181 * Firmware with HTT older than 3.0 delivers incorrect tx status for
3182 * NullFunc frames to driver. However there's a HTT Mgmt Tx command
3183 * which seems to deliver correct tx reports for NullFunc frames. The
3184 * downside of using it is it ignores client powersave state so it can
3185 * end up disconnecting sleeping clients in AP mode. It should fix STA
3186 * mode though because AP don't sleep.
3187 */
3188 if (ar->htt.target_version_major < 3 &&
3189 (ieee80211_is_nullfunc(fc) || ieee80211_is_qos_nullfunc(fc)) &&
3190 !test_bit(ATH10K_FW_FEATURE_HAS_WMI_MGMT_TX, ar->fw_features))
3191 return ATH10K_HW_TXRX_MGMT;
3192
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03003193 /* Workaround:
3194 *
3195 * Some wmi-tlv firmwares for qca6174 have broken Tx key selection for
3196 * NativeWifi txmode - it selects AP key instead of peer key. It seems
3197 * to work with Ethernet txmode so use it.
David Liuccec9032015-07-24 20:25:32 +03003198 *
3199 * FIXME: Check if raw mode works with TDLS.
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03003200 */
3201 if (ieee80211_is_data_present(fc) && sta && sta->tdls)
3202 return ATH10K_HW_TXRX_ETHERNET;
3203
David Liuccec9032015-07-24 20:25:32 +03003204 if (test_bit(ATH10K_FLAG_RAW_MODE, &ar->dev_flags))
3205 return ATH10K_HW_TXRX_RAW;
3206
Michal Kaziord740d8f2015-03-30 09:51:51 +03003207 return ATH10K_HW_TXRX_NATIVE_WIFI;
3208}
3209
David Liuccec9032015-07-24 20:25:32 +03003210static bool ath10k_tx_h_use_hwcrypto(struct ieee80211_vif *vif,
Michal Kaziorfd12cb32015-11-18 06:59:15 +01003211 struct sk_buff *skb)
3212{
3213 const struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
3214 const struct ieee80211_hdr *hdr = (void *)skb->data;
David Liuccec9032015-07-24 20:25:32 +03003215 const u32 mask = IEEE80211_TX_INTFL_DONT_ENCRYPT |
3216 IEEE80211_TX_CTL_INJECTED;
Michal Kaziorfd12cb32015-11-18 06:59:15 +01003217
3218 if (!ieee80211_has_protected(hdr->frame_control))
3219 return false;
3220
David Liuccec9032015-07-24 20:25:32 +03003221 if ((info->flags & mask) == mask)
3222 return false;
Michal Kaziorfd12cb32015-11-18 06:59:15 +01003223
David Liuccec9032015-07-24 20:25:32 +03003224 if (vif)
3225 return !ath10k_vif_to_arvif(vif)->nohwcrypt;
Michal Kaziorfd12cb32015-11-18 06:59:15 +01003226
David Liuccec9032015-07-24 20:25:32 +03003227 return true;
3228}
3229
Michal Kazior4b604552014-07-21 21:03:09 +03003230/* HTT Tx uses Native Wifi tx mode which expects 802.11 frames without QoS
3231 * Control in the header.
Kalle Valo5e3dd152013-06-12 20:52:10 +03003232 */
Michal Kazior4b604552014-07-21 21:03:09 +03003233static void ath10k_tx_h_nwifi(struct ieee80211_hw *hw, struct sk_buff *skb)
Kalle Valo5e3dd152013-06-12 20:52:10 +03003234{
3235 struct ieee80211_hdr *hdr = (void *)skb->data;
Michal Kaziorc21c64d2014-07-21 21:03:10 +03003236 struct ath10k_skb_cb *cb = ATH10K_SKB_CB(skb);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003237 u8 *qos_ctl;
3238
3239 if (!ieee80211_is_data_qos(hdr->frame_control))
3240 return;
3241
3242 qos_ctl = ieee80211_get_qos_ctl(hdr);
Michal Kaziorba0ccd72013-07-22 14:25:28 +02003243 memmove(skb->data + IEEE80211_QOS_CTL_LEN,
3244 skb->data, (void *)qos_ctl - (void *)skb->data);
3245 skb_pull(skb, IEEE80211_QOS_CTL_LEN);
Michal Kaziorc21c64d2014-07-21 21:03:10 +03003246
Michal Kazior8bad8dc2015-03-11 14:25:26 +01003247 /* Some firmware revisions don't handle sending QoS NullFunc well.
3248 * These frames are mainly used for CQM purposes so it doesn't really
3249 * matter whether QoS NullFunc or NullFunc are sent.
Michal Kaziorc21c64d2014-07-21 21:03:10 +03003250 */
Michal Kaziorbf0a26d2015-01-24 12:14:51 +02003251 hdr = (void *)skb->data;
Michal Kazior8bad8dc2015-03-11 14:25:26 +01003252 if (ieee80211_is_qos_nullfunc(hdr->frame_control))
Michal Kazior609db222015-11-18 06:59:22 +01003253 cb->flags &= ~ATH10K_SKB_F_QOS;
Michal Kazior8bad8dc2015-03-11 14:25:26 +01003254
3255 hdr->frame_control &= ~__cpu_to_le16(IEEE80211_STYPE_QOS_DATA);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003256}
3257
Michal Kaziord740d8f2015-03-30 09:51:51 +03003258static void ath10k_tx_h_8023(struct sk_buff *skb)
3259{
3260 struct ieee80211_hdr *hdr;
3261 struct rfc1042_hdr *rfc1042;
3262 struct ethhdr *eth;
3263 size_t hdrlen;
3264 u8 da[ETH_ALEN];
3265 u8 sa[ETH_ALEN];
3266 __be16 type;
3267
3268 hdr = (void *)skb->data;
3269 hdrlen = ieee80211_hdrlen(hdr->frame_control);
3270 rfc1042 = (void *)skb->data + hdrlen;
3271
3272 ether_addr_copy(da, ieee80211_get_DA(hdr));
3273 ether_addr_copy(sa, ieee80211_get_SA(hdr));
3274 type = rfc1042->snap_type;
3275
3276 skb_pull(skb, hdrlen + sizeof(*rfc1042));
3277 skb_push(skb, sizeof(*eth));
3278
3279 eth = (void *)skb->data;
3280 ether_addr_copy(eth->h_dest, da);
3281 ether_addr_copy(eth->h_source, sa);
3282 eth->h_proto = type;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003283}
3284
Michal Kazior4b604552014-07-21 21:03:09 +03003285static void ath10k_tx_h_add_p2p_noa_ie(struct ath10k *ar,
3286 struct ieee80211_vif *vif,
3287 struct sk_buff *skb)
Kalle Valo5e3dd152013-06-12 20:52:10 +03003288{
3289 struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003290 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
3291
3292 /* This is case only for P2P_GO */
Peter Oh08c27be2016-01-28 13:54:09 -08003293 if (vif->type != NL80211_IFTYPE_AP || !vif->p2p)
Kalle Valo5e3dd152013-06-12 20:52:10 +03003294 return;
3295
3296 if (unlikely(ieee80211_is_probe_resp(hdr->frame_control))) {
3297 spin_lock_bh(&ar->data_lock);
3298 if (arvif->u.ap.noa_data)
3299 if (!pskb_expand_head(skb, 0, arvif->u.ap.noa_len,
3300 GFP_ATOMIC))
3301 memcpy(skb_put(skb, arvif->u.ap.noa_len),
3302 arvif->u.ap.noa_data,
3303 arvif->u.ap.noa_len);
3304 spin_unlock_bh(&ar->data_lock);
3305 }
3306}
3307
Michal Kaziorf2f6eca2016-03-01 11:32:46 +01003308static void ath10k_mac_tx_h_fill_cb(struct ath10k *ar,
3309 struct ieee80211_vif *vif,
3310 struct sk_buff *skb)
3311{
3312 struct ieee80211_hdr *hdr = (void *)skb->data;
3313 struct ath10k_skb_cb *cb = ATH10K_SKB_CB(skb);
3314
3315 cb->flags = 0;
3316 if (!ath10k_tx_h_use_hwcrypto(vif, skb))
3317 cb->flags |= ATH10K_SKB_F_NO_HWCRYPT;
3318
3319 if (ieee80211_is_mgmt(hdr->frame_control))
3320 cb->flags |= ATH10K_SKB_F_MGMT;
3321
3322 if (ieee80211_is_data_qos(hdr->frame_control))
3323 cb->flags |= ATH10K_SKB_F_QOS;
3324
3325 cb->vif = vif;
3326}
3327
Vasanthakumar Thiagarajand39de992015-11-05 11:34:00 +05303328bool ath10k_mac_tx_frm_has_freq(struct ath10k *ar)
Michal Kazior8d6d3622014-11-24 14:58:31 +01003329{
3330 /* FIXME: Not really sure since when the behaviour changed. At some
3331 * point new firmware stopped requiring creation of peer entries for
3332 * offchannel tx (and actually creating them causes issues with wmi-htc
3333 * tx credit replenishment and reliability). Assuming it's at least 3.4
3334 * because that's when the `freq` was introduced to TX_FRM HTT command.
3335 */
Vasanthakumar Thiagarajan8921f5f2015-11-05 11:33:59 +05303336 return (ar->htt.target_version_major >= 3 &&
Vasanthakumar Thiagarajand39de992015-11-05 11:34:00 +05303337 ar->htt.target_version_minor >= 4 &&
3338 ar->htt.op_version == ATH10K_FW_HTT_OP_VERSION_TLV);
Michal Kazior8d6d3622014-11-24 14:58:31 +01003339}
3340
Michal Kaziord740d8f2015-03-30 09:51:51 +03003341static int ath10k_mac_tx_wmi_mgmt(struct ath10k *ar, struct sk_buff *skb)
Kalle Valo5e3dd152013-06-12 20:52:10 +03003342{
Michal Kaziord740d8f2015-03-30 09:51:51 +03003343 struct sk_buff_head *q = &ar->wmi_mgmt_tx_queue;
Bartosz Markowski5e00d312013-09-26 17:47:12 +02003344 int ret = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003345
Michal Kaziord740d8f2015-03-30 09:51:51 +03003346 spin_lock_bh(&ar->data_lock);
3347
3348 if (skb_queue_len(q) == ATH10K_MAX_NUM_MGMT_PENDING) {
3349 ath10k_warn(ar, "wmi mgmt tx queue is full\n");
3350 ret = -ENOSPC;
3351 goto unlock;
Michal Kazior961d4c32013-08-09 10:13:34 +02003352 }
3353
Michal Kaziord740d8f2015-03-30 09:51:51 +03003354 __skb_queue_tail(q, skb);
3355 ieee80211_queue_work(ar->hw, &ar->wmi_mgmt_tx_work);
3356
3357unlock:
3358 spin_unlock_bh(&ar->data_lock);
3359
3360 return ret;
3361}
3362
Michal Kaziora30c7d02016-03-06 16:14:23 +02003363static enum ath10k_mac_tx_path
3364ath10k_mac_tx_h_get_txpath(struct ath10k *ar,
3365 struct sk_buff *skb,
3366 enum ath10k_hw_txrx_mode txmode)
3367{
3368 switch (txmode) {
3369 case ATH10K_HW_TXRX_RAW:
3370 case ATH10K_HW_TXRX_NATIVE_WIFI:
3371 case ATH10K_HW_TXRX_ETHERNET:
3372 return ATH10K_MAC_TX_HTT;
3373 case ATH10K_HW_TXRX_MGMT:
3374 if (test_bit(ATH10K_FW_FEATURE_HAS_WMI_MGMT_TX,
3375 ar->fw_features))
3376 return ATH10K_MAC_TX_WMI_MGMT;
3377 else if (ar->htt.target_version_major >= 3)
3378 return ATH10K_MAC_TX_HTT;
3379 else
3380 return ATH10K_MAC_TX_HTT_MGMT;
3381 }
3382
3383 return ATH10K_MAC_TX_UNKNOWN;
3384}
3385
Michal Kaziorf2f6eca2016-03-01 11:32:46 +01003386static int ath10k_mac_tx_submit(struct ath10k *ar,
3387 enum ath10k_hw_txrx_mode txmode,
Michal Kazior6421969f2016-03-06 16:14:25 +02003388 enum ath10k_mac_tx_path txpath,
Michal Kaziorf2f6eca2016-03-01 11:32:46 +01003389 struct sk_buff *skb)
Michal Kaziord740d8f2015-03-30 09:51:51 +03003390{
Michal Kaziord740d8f2015-03-30 09:51:51 +03003391 struct ath10k_htt *htt = &ar->htt;
Michal Kazior6421969f2016-03-06 16:14:25 +02003392 int ret = -EINVAL;
Michal Kaziora30c7d02016-03-06 16:14:23 +02003393
3394 switch (txpath) {
3395 case ATH10K_MAC_TX_HTT:
Michal Kazior8a933962015-11-18 06:59:17 +01003396 ret = ath10k_htt_tx(htt, txmode, skb);
Michal Kaziord740d8f2015-03-30 09:51:51 +03003397 break;
Michal Kaziora30c7d02016-03-06 16:14:23 +02003398 case ATH10K_MAC_TX_HTT_MGMT:
3399 ret = ath10k_htt_mgmt_tx(htt, skb);
3400 break;
3401 case ATH10K_MAC_TX_WMI_MGMT:
3402 ret = ath10k_mac_tx_wmi_mgmt(ar, skb);
3403 break;
3404 case ATH10K_MAC_TX_UNKNOWN:
3405 WARN_ON_ONCE(1);
3406 ret = -EINVAL;
Michal Kaziord740d8f2015-03-30 09:51:51 +03003407 break;
Bartosz Markowski5e00d312013-09-26 17:47:12 +02003408 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03003409
3410 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003411 ath10k_warn(ar, "failed to transmit packet, dropping: %d\n",
3412 ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003413 ieee80211_free_txskb(ar->hw, skb);
3414 }
Michal Kaziorf2f6eca2016-03-01 11:32:46 +01003415
3416 return ret;
3417}
3418
3419/* This function consumes the sk_buff regardless of return value as far as
3420 * caller is concerned so no freeing is necessary afterwards.
3421 */
3422static int ath10k_mac_tx(struct ath10k *ar,
3423 struct ieee80211_vif *vif,
3424 struct ieee80211_sta *sta,
3425 enum ath10k_hw_txrx_mode txmode,
Michal Kazior6421969f2016-03-06 16:14:25 +02003426 enum ath10k_mac_tx_path txpath,
Michal Kaziorf2f6eca2016-03-01 11:32:46 +01003427 struct sk_buff *skb)
3428{
3429 struct ieee80211_hw *hw = ar->hw;
3430 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
3431 int ret;
3432
3433 /* We should disable CCK RATE due to P2P */
3434 if (info->flags & IEEE80211_TX_CTL_NO_CCK_RATE)
3435 ath10k_dbg(ar, ATH10K_DBG_MAC, "IEEE80211_TX_CTL_NO_CCK_RATE\n");
3436
3437 switch (txmode) {
3438 case ATH10K_HW_TXRX_MGMT:
3439 case ATH10K_HW_TXRX_NATIVE_WIFI:
3440 ath10k_tx_h_nwifi(hw, skb);
3441 ath10k_tx_h_add_p2p_noa_ie(ar, vif, skb);
3442 ath10k_tx_h_seq_no(vif, skb);
3443 break;
3444 case ATH10K_HW_TXRX_ETHERNET:
3445 ath10k_tx_h_8023(skb);
3446 break;
3447 case ATH10K_HW_TXRX_RAW:
3448 if (!test_bit(ATH10K_FLAG_RAW_MODE, &ar->dev_flags)) {
3449 WARN_ON_ONCE(1);
3450 ieee80211_free_txskb(hw, skb);
3451 return -ENOTSUPP;
3452 }
3453 }
3454
3455 if (info->flags & IEEE80211_TX_CTL_TX_OFFCHAN) {
3456 if (!ath10k_mac_tx_frm_has_freq(ar)) {
3457 ath10k_dbg(ar, ATH10K_DBG_MAC, "queued offchannel skb %p\n",
3458 skb);
3459
3460 skb_queue_tail(&ar->offchan_tx_queue, skb);
3461 ieee80211_queue_work(hw, &ar->offchan_tx_work);
3462 return 0;
3463 }
3464 }
3465
Michal Kazior6421969f2016-03-06 16:14:25 +02003466 ret = ath10k_mac_tx_submit(ar, txmode, txpath, skb);
Michal Kaziorf2f6eca2016-03-01 11:32:46 +01003467 if (ret) {
3468 ath10k_warn(ar, "failed to submit frame: %d\n", ret);
3469 return ret;
3470 }
3471
3472 return 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003473}
3474
3475void ath10k_offchan_tx_purge(struct ath10k *ar)
3476{
3477 struct sk_buff *skb;
3478
3479 for (;;) {
3480 skb = skb_dequeue(&ar->offchan_tx_queue);
3481 if (!skb)
3482 break;
3483
3484 ieee80211_free_txskb(ar->hw, skb);
3485 }
3486}
3487
3488void ath10k_offchan_tx_work(struct work_struct *work)
3489{
3490 struct ath10k *ar = container_of(work, struct ath10k, offchan_tx_work);
3491 struct ath10k_peer *peer;
Michal Kazior8a933962015-11-18 06:59:17 +01003492 struct ath10k_vif *arvif;
Michal Kaziorf2f6eca2016-03-01 11:32:46 +01003493 enum ath10k_hw_txrx_mode txmode;
Michal Kazior6421969f2016-03-06 16:14:25 +02003494 enum ath10k_mac_tx_path txpath;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003495 struct ieee80211_hdr *hdr;
Michal Kazior8a933962015-11-18 06:59:17 +01003496 struct ieee80211_vif *vif;
3497 struct ieee80211_sta *sta;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003498 struct sk_buff *skb;
3499 const u8 *peer_addr;
3500 int vdev_id;
3501 int ret;
Nicholas Mc Guire8e9904f52015-03-30 15:39:19 +03003502 unsigned long time_left;
Michal Kazioradaeed72015-08-05 12:15:23 +02003503 bool tmp_peer_created = false;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003504
3505 /* FW requirement: We must create a peer before FW will send out
3506 * an offchannel frame. Otherwise the frame will be stuck and
3507 * never transmitted. We delete the peer upon tx completion.
3508 * It is unlikely that a peer for offchannel tx will already be
3509 * present. However it may be in some rare cases so account for that.
3510 * Otherwise we might remove a legitimate peer and break stuff. */
3511
3512 for (;;) {
3513 skb = skb_dequeue(&ar->offchan_tx_queue);
3514 if (!skb)
3515 break;
3516
3517 mutex_lock(&ar->conf_mutex);
3518
Michal Kazior7aa7a722014-08-25 12:09:38 +02003519 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac offchannel skb %p\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03003520 skb);
3521
3522 hdr = (struct ieee80211_hdr *)skb->data;
3523 peer_addr = ieee80211_get_DA(hdr);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003524
3525 spin_lock_bh(&ar->data_lock);
Michal Kazior609db222015-11-18 06:59:22 +01003526 vdev_id = ar->scan.vdev_id;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003527 peer = ath10k_peer_find(ar, vdev_id, peer_addr);
3528 spin_unlock_bh(&ar->data_lock);
3529
3530 if (peer)
Kalle Valo60c3daa2013-09-08 17:56:07 +03003531 /* FIXME: should this use ath10k_warn()? */
Michal Kazior7aa7a722014-08-25 12:09:38 +02003532 ath10k_dbg(ar, ATH10K_DBG_MAC, "peer %pM on vdev %d already present\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03003533 peer_addr, vdev_id);
3534
3535 if (!peer) {
Michal Kazior69427262016-03-06 16:14:30 +02003536 ret = ath10k_peer_create(ar, NULL, NULL, vdev_id,
3537 peer_addr,
Marek Puzyniak7390ed32015-03-30 09:51:52 +03003538 WMI_PEER_TYPE_DEFAULT);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003539 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003540 ath10k_warn(ar, "failed to create peer %pM on vdev %d: %d\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03003541 peer_addr, vdev_id, ret);
Michal Kazioradaeed72015-08-05 12:15:23 +02003542 tmp_peer_created = (ret == 0);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003543 }
3544
3545 spin_lock_bh(&ar->data_lock);
Wolfram Sang16735d02013-11-14 14:32:02 -08003546 reinit_completion(&ar->offchan_tx_completed);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003547 ar->offchan_tx_skb = skb;
3548 spin_unlock_bh(&ar->data_lock);
3549
Michal Kazior8a933962015-11-18 06:59:17 +01003550 /* It's safe to access vif and sta - conf_mutex guarantees that
3551 * sta_state() and remove_interface() are locked exclusively
3552 * out wrt to this offchannel worker.
3553 */
3554 arvif = ath10k_get_arvif(ar, vdev_id);
3555 if (arvif) {
3556 vif = arvif->vif;
3557 sta = ieee80211_find_sta(vif, peer_addr);
3558 } else {
3559 vif = NULL;
3560 sta = NULL;
3561 }
3562
3563 txmode = ath10k_mac_tx_h_get_txmode(ar, vif, sta, skb);
Michal Kazior6421969f2016-03-06 16:14:25 +02003564 txpath = ath10k_mac_tx_h_get_txpath(ar, skb, txmode);
Michal Kazior8a933962015-11-18 06:59:17 +01003565
Michal Kazior6421969f2016-03-06 16:14:25 +02003566 ret = ath10k_mac_tx(ar, vif, sta, txmode, txpath, skb);
Michal Kaziorf2f6eca2016-03-01 11:32:46 +01003567 if (ret) {
3568 ath10k_warn(ar, "failed to transmit offchannel frame: %d\n",
3569 ret);
3570 /* not serious */
3571 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03003572
Nicholas Mc Guire8e9904f52015-03-30 15:39:19 +03003573 time_left =
3574 wait_for_completion_timeout(&ar->offchan_tx_completed, 3 * HZ);
3575 if (time_left == 0)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003576 ath10k_warn(ar, "timed out waiting for offchannel skb %p\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03003577 skb);
3578
Michal Kazioradaeed72015-08-05 12:15:23 +02003579 if (!peer && tmp_peer_created) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03003580 ret = ath10k_peer_delete(ar, vdev_id, peer_addr);
3581 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003582 ath10k_warn(ar, "failed to delete peer %pM on vdev %d: %d\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03003583 peer_addr, vdev_id, ret);
3584 }
3585
3586 mutex_unlock(&ar->conf_mutex);
3587 }
3588}
3589
Bartosz Markowski5e00d312013-09-26 17:47:12 +02003590void ath10k_mgmt_over_wmi_tx_purge(struct ath10k *ar)
3591{
3592 struct sk_buff *skb;
3593
3594 for (;;) {
3595 skb = skb_dequeue(&ar->wmi_mgmt_tx_queue);
3596 if (!skb)
3597 break;
3598
3599 ieee80211_free_txskb(ar->hw, skb);
3600 }
3601}
3602
3603void ath10k_mgmt_over_wmi_tx_work(struct work_struct *work)
3604{
3605 struct ath10k *ar = container_of(work, struct ath10k, wmi_mgmt_tx_work);
3606 struct sk_buff *skb;
3607 int ret;
3608
3609 for (;;) {
3610 skb = skb_dequeue(&ar->wmi_mgmt_tx_queue);
3611 if (!skb)
3612 break;
3613
3614 ret = ath10k_wmi_mgmt_tx(ar, skb);
Michal Kazior5fb5e412013-10-28 07:18:13 +01003615 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003616 ath10k_warn(ar, "failed to transmit management frame via WMI: %d\n",
Kalle Valobe6546f2014-03-25 14:18:51 +02003617 ret);
Michal Kazior5fb5e412013-10-28 07:18:13 +01003618 ieee80211_free_txskb(ar->hw, skb);
3619 }
Bartosz Markowski5e00d312013-09-26 17:47:12 +02003620 }
3621}
3622
Kalle Valo5e3dd152013-06-12 20:52:10 +03003623/************/
3624/* Scanning */
3625/************/
3626
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003627void __ath10k_scan_finish(struct ath10k *ar)
Kalle Valo5e3dd152013-06-12 20:52:10 +03003628{
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003629 lockdep_assert_held(&ar->data_lock);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003630
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003631 switch (ar->scan.state) {
3632 case ATH10K_SCAN_IDLE:
3633 break;
3634 case ATH10K_SCAN_RUNNING:
Michal Kazior7305d3e2014-11-24 14:58:33 +01003635 case ATH10K_SCAN_ABORTING:
3636 if (!ar->scan.is_roc)
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003637 ieee80211_scan_completed(ar->hw,
3638 (ar->scan.state ==
3639 ATH10K_SCAN_ABORTING));
Michal Kaziord710e752015-07-09 13:08:36 +02003640 else if (ar->scan.roc_notify)
3641 ieee80211_remain_on_channel_expired(ar->hw);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003642 /* fall through */
3643 case ATH10K_SCAN_STARTING:
3644 ar->scan.state = ATH10K_SCAN_IDLE;
3645 ar->scan_channel = NULL;
Michal Kaziorbd877442015-11-18 06:59:19 +01003646 ar->scan.roc_freq = 0;
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003647 ath10k_offchan_tx_purge(ar);
3648 cancel_delayed_work(&ar->scan.timeout);
3649 complete_all(&ar->scan.completed);
3650 break;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003651 }
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003652}
Kalle Valo5e3dd152013-06-12 20:52:10 +03003653
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003654void ath10k_scan_finish(struct ath10k *ar)
3655{
3656 spin_lock_bh(&ar->data_lock);
3657 __ath10k_scan_finish(ar);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003658 spin_unlock_bh(&ar->data_lock);
3659}
3660
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003661static int ath10k_scan_stop(struct ath10k *ar)
Kalle Valo5e3dd152013-06-12 20:52:10 +03003662{
3663 struct wmi_stop_scan_arg arg = {
3664 .req_id = 1, /* FIXME */
3665 .req_type = WMI_SCAN_STOP_ONE,
3666 .u.scan_id = ATH10K_SCAN_ID,
3667 };
3668 int ret;
3669
3670 lockdep_assert_held(&ar->conf_mutex);
3671
Kalle Valo5e3dd152013-06-12 20:52:10 +03003672 ret = ath10k_wmi_stop_scan(ar, &arg);
3673 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003674 ath10k_warn(ar, "failed to stop wmi scan: %d\n", ret);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003675 goto out;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003676 }
3677
Kalle Valo5e3dd152013-06-12 20:52:10 +03003678 ret = wait_for_completion_timeout(&ar->scan.completed, 3*HZ);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003679 if (ret == 0) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003680 ath10k_warn(ar, "failed to receive scan abortion completion: timed out\n");
Kalle Valo5e3dd152013-06-12 20:52:10 +03003681 ret = -ETIMEDOUT;
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003682 } else if (ret > 0) {
3683 ret = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003684 }
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003685
3686out:
3687 /* Scan state should be updated upon scan completion but in case
3688 * firmware fails to deliver the event (for whatever reason) it is
3689 * desired to clean up scan state anyway. Firmware may have just
3690 * dropped the scan completion event delivery due to transport pipe
3691 * being overflown with data and/or it can recover on its own before
3692 * next scan request is submitted.
3693 */
3694 spin_lock_bh(&ar->data_lock);
3695 if (ar->scan.state != ATH10K_SCAN_IDLE)
3696 __ath10k_scan_finish(ar);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003697 spin_unlock_bh(&ar->data_lock);
3698
3699 return ret;
3700}
3701
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003702static void ath10k_scan_abort(struct ath10k *ar)
3703{
3704 int ret;
3705
3706 lockdep_assert_held(&ar->conf_mutex);
3707
3708 spin_lock_bh(&ar->data_lock);
3709
3710 switch (ar->scan.state) {
3711 case ATH10K_SCAN_IDLE:
3712 /* This can happen if timeout worker kicked in and called
3713 * abortion while scan completion was being processed.
3714 */
3715 break;
3716 case ATH10K_SCAN_STARTING:
3717 case ATH10K_SCAN_ABORTING:
Michal Kazior7aa7a722014-08-25 12:09:38 +02003718 ath10k_warn(ar, "refusing scan abortion due to invalid scan state: %s (%d)\n",
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003719 ath10k_scan_state_str(ar->scan.state),
3720 ar->scan.state);
3721 break;
3722 case ATH10K_SCAN_RUNNING:
3723 ar->scan.state = ATH10K_SCAN_ABORTING;
3724 spin_unlock_bh(&ar->data_lock);
3725
3726 ret = ath10k_scan_stop(ar);
3727 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003728 ath10k_warn(ar, "failed to abort scan: %d\n", ret);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003729
3730 spin_lock_bh(&ar->data_lock);
3731 break;
3732 }
3733
3734 spin_unlock_bh(&ar->data_lock);
3735}
3736
3737void ath10k_scan_timeout_work(struct work_struct *work)
3738{
3739 struct ath10k *ar = container_of(work, struct ath10k,
3740 scan.timeout.work);
3741
3742 mutex_lock(&ar->conf_mutex);
3743 ath10k_scan_abort(ar);
3744 mutex_unlock(&ar->conf_mutex);
3745}
3746
Kalle Valo5e3dd152013-06-12 20:52:10 +03003747static int ath10k_start_scan(struct ath10k *ar,
3748 const struct wmi_start_scan_arg *arg)
3749{
3750 int ret;
3751
3752 lockdep_assert_held(&ar->conf_mutex);
3753
3754 ret = ath10k_wmi_start_scan(ar, arg);
3755 if (ret)
3756 return ret;
3757
Kalle Valo5e3dd152013-06-12 20:52:10 +03003758 ret = wait_for_completion_timeout(&ar->scan.started, 1*HZ);
3759 if (ret == 0) {
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003760 ret = ath10k_scan_stop(ar);
3761 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003762 ath10k_warn(ar, "failed to stop scan: %d\n", ret);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003763
3764 return -ETIMEDOUT;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003765 }
3766
Ben Greear2f9eec02015-02-15 16:50:38 +02003767 /* If we failed to start the scan, return error code at
3768 * this point. This is probably due to some issue in the
3769 * firmware, but no need to wedge the driver due to that...
3770 */
3771 spin_lock_bh(&ar->data_lock);
3772 if (ar->scan.state == ATH10K_SCAN_IDLE) {
3773 spin_unlock_bh(&ar->data_lock);
3774 return -EINVAL;
3775 }
3776 spin_unlock_bh(&ar->data_lock);
3777
Kalle Valo5e3dd152013-06-12 20:52:10 +03003778 return 0;
3779}
3780
3781/**********************/
3782/* mac80211 callbacks */
3783/**********************/
3784
Michal Kaziorf2f6eca2016-03-01 11:32:46 +01003785static void ath10k_mac_op_tx(struct ieee80211_hw *hw,
3786 struct ieee80211_tx_control *control,
3787 struct sk_buff *skb)
Kalle Valo5e3dd152013-06-12 20:52:10 +03003788{
Kalle Valo5e3dd152013-06-12 20:52:10 +03003789 struct ath10k *ar = hw->priv;
Michal Kazior6421969f2016-03-06 16:14:25 +02003790 struct ath10k_htt *htt = &ar->htt;
Michal Kazior4b604552014-07-21 21:03:09 +03003791 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
3792 struct ieee80211_vif *vif = info->control.vif;
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03003793 struct ieee80211_sta *sta = control->sta;
Michal Kazior6421969f2016-03-06 16:14:25 +02003794 struct ieee80211_hdr *hdr = (void *)skb->data;
Michal Kazior8a933962015-11-18 06:59:17 +01003795 enum ath10k_hw_txrx_mode txmode;
Michal Kazior6421969f2016-03-06 16:14:25 +02003796 enum ath10k_mac_tx_path txpath;
3797 bool is_htt;
3798 bool is_mgmt;
3799 bool is_presp;
Michal Kaziorf2f6eca2016-03-01 11:32:46 +01003800 int ret;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003801
Michal Kaziorf2f6eca2016-03-01 11:32:46 +01003802 ath10k_mac_tx_h_fill_cb(ar, vif, skb);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003803
Michal Kazior8a933962015-11-18 06:59:17 +01003804 txmode = ath10k_mac_tx_h_get_txmode(ar, vif, sta, skb);
Michal Kazior6421969f2016-03-06 16:14:25 +02003805 txpath = ath10k_mac_tx_h_get_txpath(ar, skb, txmode);
3806 is_htt = (txpath == ATH10K_MAC_TX_HTT ||
3807 txpath == ATH10K_MAC_TX_HTT_MGMT);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003808
Michal Kazior6421969f2016-03-06 16:14:25 +02003809 if (is_htt) {
3810 spin_lock_bh(&ar->htt.tx_lock);
3811
3812 is_mgmt = ieee80211_is_mgmt(hdr->frame_control);
3813 is_presp = ieee80211_is_probe_resp(hdr->frame_control);
3814
3815 ret = ath10k_htt_tx_inc_pending(htt, is_mgmt, is_presp);
3816 if (ret) {
3817 ath10k_warn(ar, "failed to increase tx pending count: %d, dropping\n",
3818 ret);
3819 spin_unlock_bh(&ar->htt.tx_lock);
3820 ieee80211_free_txskb(ar->hw, skb);
3821 return;
3822 }
3823
3824 spin_unlock_bh(&ar->htt.tx_lock);
3825 }
3826
3827 ret = ath10k_mac_tx(ar, vif, sta, txmode, txpath, skb);
3828 if (ret) {
Michal Kaziorf2f6eca2016-03-01 11:32:46 +01003829 ath10k_warn(ar, "failed to transmit frame: %d\n", ret);
Michal Kazior6421969f2016-03-06 16:14:25 +02003830 if (is_htt) {
3831 spin_lock_bh(&ar->htt.tx_lock);
3832 ath10k_htt_tx_dec_pending(htt, is_mgmt);
3833 spin_unlock_bh(&ar->htt.tx_lock);
3834 }
3835 return;
3836 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03003837}
3838
Michal Kaziorbca7baf2014-05-26 12:46:03 +03003839/* Must not be called with conf_mutex held as workers can use that also. */
Michal Kazior7962b0d2014-10-28 10:34:38 +01003840void ath10k_drain_tx(struct ath10k *ar)
Michal Kaziorbca7baf2014-05-26 12:46:03 +03003841{
3842 /* make sure rcu-protected mac80211 tx path itself is drained */
3843 synchronize_net();
3844
3845 ath10k_offchan_tx_purge(ar);
3846 ath10k_mgmt_over_wmi_tx_purge(ar);
3847
3848 cancel_work_sync(&ar->offchan_tx_work);
3849 cancel_work_sync(&ar->wmi_mgmt_tx_work);
3850}
3851
Michal Kazioraffd3212013-07-16 09:54:35 +02003852void ath10k_halt(struct ath10k *ar)
Michal Kazior818bdd12013-07-16 09:38:57 +02003853{
Michal Kaziord9bc4b92014-04-23 19:30:06 +03003854 struct ath10k_vif *arvif;
3855
Michal Kazior818bdd12013-07-16 09:38:57 +02003856 lockdep_assert_held(&ar->conf_mutex);
3857
Michal Kazior19337472014-08-28 12:58:16 +02003858 clear_bit(ATH10K_CAC_RUNNING, &ar->dev_flags);
3859 ar->filter_flags = 0;
3860 ar->monitor = false;
Michal Kazior500ff9f2015-03-31 10:26:21 +00003861 ar->monitor_arvif = NULL;
Michal Kazior19337472014-08-28 12:58:16 +02003862
3863 if (ar->monitor_started)
Michal Kazior1bbc0972014-04-08 09:45:47 +03003864 ath10k_monitor_stop(ar);
Michal Kazior19337472014-08-28 12:58:16 +02003865
3866 ar->monitor_started = false;
Michal Kazior96d828d2015-03-31 10:26:23 +00003867 ar->tx_paused = 0;
Michal Kazior1bbc0972014-04-08 09:45:47 +03003868
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003869 ath10k_scan_finish(ar);
Michal Kazior818bdd12013-07-16 09:38:57 +02003870 ath10k_peer_cleanup_all(ar);
3871 ath10k_core_stop(ar);
3872 ath10k_hif_power_down(ar);
3873
3874 spin_lock_bh(&ar->data_lock);
Michal Kazior64badcb2014-09-18 11:18:02 +03003875 list_for_each_entry(arvif, &ar->arvifs, list)
3876 ath10k_mac_vif_beacon_cleanup(arvif);
Michal Kazior818bdd12013-07-16 09:38:57 +02003877 spin_unlock_bh(&ar->data_lock);
3878}
3879
Ben Greear46acf7b2014-05-16 17:15:38 +03003880static int ath10k_get_antenna(struct ieee80211_hw *hw, u32 *tx_ant, u32 *rx_ant)
3881{
3882 struct ath10k *ar = hw->priv;
3883
3884 mutex_lock(&ar->conf_mutex);
3885
Rajkumar Manoharan166de3f2015-10-27 17:51:11 +05303886 *tx_ant = ar->cfg_tx_chainmask;
3887 *rx_ant = ar->cfg_rx_chainmask;
Ben Greear46acf7b2014-05-16 17:15:38 +03003888
3889 mutex_unlock(&ar->conf_mutex);
3890
3891 return 0;
3892}
3893
Ben Greear5572a952014-11-24 16:22:10 +02003894static void ath10k_check_chain_mask(struct ath10k *ar, u32 cm, const char *dbg)
3895{
3896 /* It is not clear that allowing gaps in chainmask
3897 * is helpful. Probably it will not do what user
3898 * is hoping for, so warn in that case.
3899 */
3900 if (cm == 15 || cm == 7 || cm == 3 || cm == 1 || cm == 0)
3901 return;
3902
3903 ath10k_warn(ar, "mac %s antenna chainmask may be invalid: 0x%x. Suggested values: 15, 7, 3, 1 or 0.\n",
3904 dbg, cm);
3905}
3906
Rajkumar Manoharanf58512f2015-10-27 17:51:13 +05303907static int ath10k_mac_get_vht_cap_bf_sts(struct ath10k *ar)
3908{
3909 int nsts = ar->vht_cap_info;
3910
3911 nsts &= IEEE80211_VHT_CAP_BEAMFORMEE_STS_MASK;
3912 nsts >>= IEEE80211_VHT_CAP_BEAMFORMEE_STS_SHIFT;
3913
3914 /* If firmware does not deliver to host number of space-time
3915 * streams supported, assume it support up to 4 BF STS and return
3916 * the value for VHT CAP: nsts-1)
3917 */
3918 if (nsts == 0)
3919 return 3;
3920
3921 return nsts;
3922}
3923
3924static int ath10k_mac_get_vht_cap_bf_sound_dim(struct ath10k *ar)
3925{
3926 int sound_dim = ar->vht_cap_info;
3927
3928 sound_dim &= IEEE80211_VHT_CAP_SOUNDING_DIMENSIONS_MASK;
3929 sound_dim >>= IEEE80211_VHT_CAP_SOUNDING_DIMENSIONS_SHIFT;
3930
3931 /* If the sounding dimension is not advertised by the firmware,
3932 * let's use a default value of 1
3933 */
3934 if (sound_dim == 0)
3935 return 1;
3936
3937 return sound_dim;
3938}
3939
3940static struct ieee80211_sta_vht_cap ath10k_create_vht_cap(struct ath10k *ar)
3941{
3942 struct ieee80211_sta_vht_cap vht_cap = {0};
3943 u16 mcs_map;
3944 u32 val;
3945 int i;
3946
3947 vht_cap.vht_supported = 1;
3948 vht_cap.cap = ar->vht_cap_info;
3949
3950 if (ar->vht_cap_info & (IEEE80211_VHT_CAP_SU_BEAMFORMEE_CAPABLE |
3951 IEEE80211_VHT_CAP_MU_BEAMFORMEE_CAPABLE)) {
3952 val = ath10k_mac_get_vht_cap_bf_sts(ar);
3953 val <<= IEEE80211_VHT_CAP_BEAMFORMEE_STS_SHIFT;
3954 val &= IEEE80211_VHT_CAP_BEAMFORMEE_STS_MASK;
3955
3956 vht_cap.cap |= val;
3957 }
3958
3959 if (ar->vht_cap_info & (IEEE80211_VHT_CAP_SU_BEAMFORMER_CAPABLE |
3960 IEEE80211_VHT_CAP_MU_BEAMFORMER_CAPABLE)) {
3961 val = ath10k_mac_get_vht_cap_bf_sound_dim(ar);
3962 val <<= IEEE80211_VHT_CAP_SOUNDING_DIMENSIONS_SHIFT;
3963 val &= IEEE80211_VHT_CAP_SOUNDING_DIMENSIONS_MASK;
3964
3965 vht_cap.cap |= val;
3966 }
3967
3968 mcs_map = 0;
3969 for (i = 0; i < 8; i++) {
3970 if ((i < ar->num_rf_chains) && (ar->cfg_tx_chainmask & BIT(i)))
3971 mcs_map |= IEEE80211_VHT_MCS_SUPPORT_0_9 << (i * 2);
3972 else
3973 mcs_map |= IEEE80211_VHT_MCS_NOT_SUPPORTED << (i * 2);
3974 }
3975
3976 vht_cap.vht_mcs.rx_mcs_map = cpu_to_le16(mcs_map);
3977 vht_cap.vht_mcs.tx_mcs_map = cpu_to_le16(mcs_map);
3978
3979 return vht_cap;
3980}
3981
3982static struct ieee80211_sta_ht_cap ath10k_get_ht_cap(struct ath10k *ar)
3983{
3984 int i;
3985 struct ieee80211_sta_ht_cap ht_cap = {0};
3986
3987 if (!(ar->ht_cap_info & WMI_HT_CAP_ENABLED))
3988 return ht_cap;
3989
3990 ht_cap.ht_supported = 1;
3991 ht_cap.ampdu_factor = IEEE80211_HT_MAX_AMPDU_64K;
3992 ht_cap.ampdu_density = IEEE80211_HT_MPDU_DENSITY_8;
3993 ht_cap.cap |= IEEE80211_HT_CAP_SUP_WIDTH_20_40;
3994 ht_cap.cap |= IEEE80211_HT_CAP_DSSSCCK40;
Peter Ohe33a99e2015-12-31 15:26:20 +02003995 ht_cap.cap |=
3996 WLAN_HT_CAP_SM_PS_DISABLED << IEEE80211_HT_CAP_SM_PS_SHIFT;
Rajkumar Manoharanf58512f2015-10-27 17:51:13 +05303997
3998 if (ar->ht_cap_info & WMI_HT_CAP_HT20_SGI)
3999 ht_cap.cap |= IEEE80211_HT_CAP_SGI_20;
4000
4001 if (ar->ht_cap_info & WMI_HT_CAP_HT40_SGI)
4002 ht_cap.cap |= IEEE80211_HT_CAP_SGI_40;
4003
4004 if (ar->ht_cap_info & WMI_HT_CAP_DYNAMIC_SMPS) {
4005 u32 smps;
4006
4007 smps = WLAN_HT_CAP_SM_PS_DYNAMIC;
4008 smps <<= IEEE80211_HT_CAP_SM_PS_SHIFT;
4009
4010 ht_cap.cap |= smps;
4011 }
4012
4013 if (ar->ht_cap_info & WMI_HT_CAP_TX_STBC)
4014 ht_cap.cap |= IEEE80211_HT_CAP_TX_STBC;
4015
4016 if (ar->ht_cap_info & WMI_HT_CAP_RX_STBC) {
4017 u32 stbc;
4018
4019 stbc = ar->ht_cap_info;
4020 stbc &= WMI_HT_CAP_RX_STBC;
4021 stbc >>= WMI_HT_CAP_RX_STBC_MASK_SHIFT;
4022 stbc <<= IEEE80211_HT_CAP_RX_STBC_SHIFT;
4023 stbc &= IEEE80211_HT_CAP_RX_STBC;
4024
4025 ht_cap.cap |= stbc;
4026 }
4027
4028 if (ar->ht_cap_info & WMI_HT_CAP_LDPC)
4029 ht_cap.cap |= IEEE80211_HT_CAP_LDPC_CODING;
4030
4031 if (ar->ht_cap_info & WMI_HT_CAP_L_SIG_TXOP_PROT)
4032 ht_cap.cap |= IEEE80211_HT_CAP_LSIG_TXOP_PROT;
4033
4034 /* max AMSDU is implicitly taken from vht_cap_info */
4035 if (ar->vht_cap_info & WMI_VHT_CAP_MAX_MPDU_LEN_MASK)
4036 ht_cap.cap |= IEEE80211_HT_CAP_MAX_AMSDU;
4037
4038 for (i = 0; i < ar->num_rf_chains; i++) {
4039 if (ar->cfg_rx_chainmask & BIT(i))
4040 ht_cap.mcs.rx_mask[i] = 0xFF;
4041 }
4042
4043 ht_cap.mcs.tx_params |= IEEE80211_HT_MCS_TX_DEFINED;
4044
4045 return ht_cap;
4046}
4047
Rajkumar Manoharan5036fe02015-10-27 17:51:14 +05304048static void ath10k_mac_setup_ht_vht_cap(struct ath10k *ar)
4049{
4050 struct ieee80211_supported_band *band;
4051 struct ieee80211_sta_vht_cap vht_cap;
4052 struct ieee80211_sta_ht_cap ht_cap;
4053
4054 ht_cap = ath10k_get_ht_cap(ar);
4055 vht_cap = ath10k_create_vht_cap(ar);
4056
4057 if (ar->phy_capability & WHAL_WLAN_11G_CAPABILITY) {
4058 band = &ar->mac.sbands[IEEE80211_BAND_2GHZ];
4059 band->ht_cap = ht_cap;
4060
4061 /* Enable the VHT support at 2.4 GHz */
4062 band->vht_cap = vht_cap;
4063 }
4064 if (ar->phy_capability & WHAL_WLAN_11A_CAPABILITY) {
4065 band = &ar->mac.sbands[IEEE80211_BAND_5GHZ];
4066 band->ht_cap = ht_cap;
4067 band->vht_cap = vht_cap;
4068 }
4069}
4070
Ben Greear46acf7b2014-05-16 17:15:38 +03004071static int __ath10k_set_antenna(struct ath10k *ar, u32 tx_ant, u32 rx_ant)
4072{
4073 int ret;
4074
4075 lockdep_assert_held(&ar->conf_mutex);
4076
Ben Greear5572a952014-11-24 16:22:10 +02004077 ath10k_check_chain_mask(ar, tx_ant, "tx");
4078 ath10k_check_chain_mask(ar, rx_ant, "rx");
4079
Ben Greear46acf7b2014-05-16 17:15:38 +03004080 ar->cfg_tx_chainmask = tx_ant;
4081 ar->cfg_rx_chainmask = rx_ant;
4082
4083 if ((ar->state != ATH10K_STATE_ON) &&
4084 (ar->state != ATH10K_STATE_RESTARTED))
4085 return 0;
4086
4087 ret = ath10k_wmi_pdev_set_param(ar, ar->wmi.pdev_param->tx_chain_mask,
4088 tx_ant);
4089 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004090 ath10k_warn(ar, "failed to set tx-chainmask: %d, req 0x%x\n",
Ben Greear46acf7b2014-05-16 17:15:38 +03004091 ret, tx_ant);
4092 return ret;
4093 }
4094
4095 ret = ath10k_wmi_pdev_set_param(ar, ar->wmi.pdev_param->rx_chain_mask,
4096 rx_ant);
4097 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004098 ath10k_warn(ar, "failed to set rx-chainmask: %d, req 0x%x\n",
Ben Greear46acf7b2014-05-16 17:15:38 +03004099 ret, rx_ant);
4100 return ret;
4101 }
4102
Rajkumar Manoharan5036fe02015-10-27 17:51:14 +05304103 /* Reload HT/VHT capability */
4104 ath10k_mac_setup_ht_vht_cap(ar);
4105
Ben Greear46acf7b2014-05-16 17:15:38 +03004106 return 0;
4107}
4108
4109static int ath10k_set_antenna(struct ieee80211_hw *hw, u32 tx_ant, u32 rx_ant)
4110{
4111 struct ath10k *ar = hw->priv;
4112 int ret;
4113
4114 mutex_lock(&ar->conf_mutex);
4115 ret = __ath10k_set_antenna(ar, tx_ant, rx_ant);
4116 mutex_unlock(&ar->conf_mutex);
4117 return ret;
4118}
4119
Kalle Valo5e3dd152013-06-12 20:52:10 +03004120static int ath10k_start(struct ieee80211_hw *hw)
4121{
4122 struct ath10k *ar = hw->priv;
Mohammed Shafi Shajakhan1fe374f2016-01-13 21:16:30 +05304123 u32 param;
Michal Kazior818bdd12013-07-16 09:38:57 +02004124 int ret = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004125
Michal Kaziorbca7baf2014-05-26 12:46:03 +03004126 /*
4127 * This makes sense only when restarting hw. It is harmless to call
4128 * uncoditionally. This is necessary to make sure no HTT/WMI tx
4129 * commands will be submitted while restarting.
4130 */
4131 ath10k_drain_tx(ar);
4132
Michal Kazior548db542013-07-05 16:15:15 +03004133 mutex_lock(&ar->conf_mutex);
4134
Michal Kaziorc5058f52014-05-26 12:46:03 +03004135 switch (ar->state) {
4136 case ATH10K_STATE_OFF:
4137 ar->state = ATH10K_STATE_ON;
4138 break;
4139 case ATH10K_STATE_RESTARTING:
4140 ath10k_halt(ar);
4141 ar->state = ATH10K_STATE_RESTARTED;
4142 break;
4143 case ATH10K_STATE_ON:
4144 case ATH10K_STATE_RESTARTED:
4145 case ATH10K_STATE_WEDGED:
4146 WARN_ON(1);
Michal Kazior818bdd12013-07-16 09:38:57 +02004147 ret = -EINVAL;
Michal Kaziorae254432014-05-26 12:46:02 +03004148 goto err;
Kalle Valo43d2a302014-09-10 18:23:30 +03004149 case ATH10K_STATE_UTF:
4150 ret = -EBUSY;
4151 goto err;
Michal Kazior818bdd12013-07-16 09:38:57 +02004152 }
4153
4154 ret = ath10k_hif_power_up(ar);
4155 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004156 ath10k_err(ar, "Could not init hif: %d\n", ret);
Michal Kaziorae254432014-05-26 12:46:02 +03004157 goto err_off;
Michal Kazior818bdd12013-07-16 09:38:57 +02004158 }
4159
Kalle Valo43d2a302014-09-10 18:23:30 +03004160 ret = ath10k_core_start(ar, ATH10K_FIRMWARE_MODE_NORMAL);
Michal Kazior818bdd12013-07-16 09:38:57 +02004161 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004162 ath10k_err(ar, "Could not init core: %d\n", ret);
Michal Kaziorae254432014-05-26 12:46:02 +03004163 goto err_power_down;
Michal Kazior818bdd12013-07-16 09:38:57 +02004164 }
4165
Mohammed Shafi Shajakhan1fe374f2016-01-13 21:16:30 +05304166 param = ar->wmi.pdev_param->pmf_qos;
4167 ret = ath10k_wmi_pdev_set_param(ar, param, 1);
Michal Kaziorae254432014-05-26 12:46:02 +03004168 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004169 ath10k_warn(ar, "failed to enable PMF QOS: %d\n", ret);
Michal Kaziorae254432014-05-26 12:46:02 +03004170 goto err_core_stop;
4171 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004172
Mohammed Shafi Shajakhan1fe374f2016-01-13 21:16:30 +05304173 param = ar->wmi.pdev_param->dynamic_bw;
4174 ret = ath10k_wmi_pdev_set_param(ar, param, 1);
Michal Kaziorae254432014-05-26 12:46:02 +03004175 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004176 ath10k_warn(ar, "failed to enable dynamic BW: %d\n", ret);
Michal Kaziorae254432014-05-26 12:46:02 +03004177 goto err_core_stop;
4178 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004179
Michal Kaziorcf327842015-03-31 10:26:25 +00004180 if (test_bit(WMI_SERVICE_ADAPTIVE_OCS, ar->wmi.svc_map)) {
4181 ret = ath10k_wmi_adaptive_qcs(ar, true);
4182 if (ret) {
4183 ath10k_warn(ar, "failed to enable adaptive qcs: %d\n",
4184 ret);
4185 goto err_core_stop;
4186 }
4187 }
4188
Janusz Dziedzic24ab13e2015-04-01 22:53:18 +03004189 if (test_bit(WMI_SERVICE_BURST, ar->wmi.svc_map)) {
Mohammed Shafi Shajakhan1fe374f2016-01-13 21:16:30 +05304190 param = ar->wmi.pdev_param->burst_enable;
4191 ret = ath10k_wmi_pdev_set_param(ar, param, 0);
Janusz Dziedzic24ab13e2015-04-01 22:53:18 +03004192 if (ret) {
4193 ath10k_warn(ar, "failed to disable burst: %d\n", ret);
4194 goto err_core_stop;
4195 }
4196 }
4197
Rajkumar Manoharan166de3f2015-10-27 17:51:11 +05304198 __ath10k_set_antenna(ar, ar->cfg_tx_chainmask, ar->cfg_rx_chainmask);
Ben Greear46acf7b2014-05-16 17:15:38 +03004199
Marek Puzyniakab6258e2014-01-29 15:03:31 +02004200 /*
4201 * By default FW set ARP frames ac to voice (6). In that case ARP
4202 * exchange is not working properly for UAPSD enabled AP. ARP requests
4203 * which arrives with access category 0 are processed by network stack
4204 * and send back with access category 0, but FW changes access category
4205 * to 6. Set ARP frames access category to best effort (0) solves
4206 * this problem.
4207 */
4208
Mohammed Shafi Shajakhan1fe374f2016-01-13 21:16:30 +05304209 param = ar->wmi.pdev_param->arp_ac_override;
4210 ret = ath10k_wmi_pdev_set_param(ar, param, 0);
Marek Puzyniakab6258e2014-01-29 15:03:31 +02004211 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004212 ath10k_warn(ar, "failed to set arp ac override parameter: %d\n",
Marek Puzyniakab6258e2014-01-29 15:03:31 +02004213 ret);
Michal Kaziorae254432014-05-26 12:46:02 +03004214 goto err_core_stop;
Marek Puzyniakab6258e2014-01-29 15:03:31 +02004215 }
4216
Maharaja62f77f02015-10-21 11:49:18 +03004217 if (test_bit(ATH10K_FW_FEATURE_SUPPORTS_ADAPTIVE_CCA,
4218 ar->fw_features)) {
4219 ret = ath10k_wmi_pdev_enable_adaptive_cca(ar, 1,
4220 WMI_CCA_DETECT_LEVEL_AUTO,
4221 WMI_CCA_DETECT_MARGIN_AUTO);
4222 if (ret) {
4223 ath10k_warn(ar, "failed to enable adaptive cca: %d\n",
4224 ret);
4225 goto err_core_stop;
4226 }
4227 }
4228
Mohammed Shafi Shajakhan1fe374f2016-01-13 21:16:30 +05304229 param = ar->wmi.pdev_param->ani_enable;
4230 ret = ath10k_wmi_pdev_set_param(ar, param, 1);
Ashok Raj Nagarajan575f1c32015-03-19 16:37:59 +05304231 if (ret) {
4232 ath10k_warn(ar, "failed to enable ani by default: %d\n",
4233 ret);
4234 goto err_core_stop;
4235 }
4236
Ashok Raj Nagarajanb3e71d72015-03-19 16:38:00 +05304237 ar->ani_enabled = true;
4238
Mohammed Shafi Shajakhan8351c052016-01-13 21:16:33 +05304239 if (test_bit(WMI_SERVICE_PEER_STATS, ar->wmi.svc_map)) {
4240 param = ar->wmi.pdev_param->peer_stats_update_period;
4241 ret = ath10k_wmi_pdev_set_param(ar, param,
4242 PEER_DEFAULT_STATS_UPDATE_PERIOD);
4243 if (ret) {
4244 ath10k_warn(ar,
4245 "failed to set peer stats period : %d\n",
4246 ret);
4247 goto err_core_stop;
4248 }
4249 }
4250
Michal Kaziord6500972014-04-08 09:56:09 +03004251 ar->num_started_vdevs = 0;
Michal Kaziorf7843d72013-07-16 09:38:52 +02004252 ath10k_regd_update(ar);
4253
Simon Wunderlich855aed12014-08-02 09:12:54 +03004254 ath10k_spectral_start(ar);
Rajkumar Manoharan8515b5c2015-03-15 20:36:22 +05304255 ath10k_thermal_set_throttling(ar);
Simon Wunderlich855aed12014-08-02 09:12:54 +03004256
Michal Kaziorae254432014-05-26 12:46:02 +03004257 mutex_unlock(&ar->conf_mutex);
4258 return 0;
4259
4260err_core_stop:
4261 ath10k_core_stop(ar);
4262
4263err_power_down:
4264 ath10k_hif_power_down(ar);
4265
4266err_off:
4267 ar->state = ATH10K_STATE_OFF;
4268
4269err:
Michal Kazior548db542013-07-05 16:15:15 +03004270 mutex_unlock(&ar->conf_mutex);
Michal Kaziorc60bdd82014-01-29 07:26:31 +01004271 return ret;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004272}
4273
4274static void ath10k_stop(struct ieee80211_hw *hw)
4275{
4276 struct ath10k *ar = hw->priv;
4277
Michal Kaziorbca7baf2014-05-26 12:46:03 +03004278 ath10k_drain_tx(ar);
4279
Michal Kazior548db542013-07-05 16:15:15 +03004280 mutex_lock(&ar->conf_mutex);
Michal Kaziorc5058f52014-05-26 12:46:03 +03004281 if (ar->state != ATH10K_STATE_OFF) {
Michal Kazior818bdd12013-07-16 09:38:57 +02004282 ath10k_halt(ar);
Michal Kaziorc5058f52014-05-26 12:46:03 +03004283 ar->state = ATH10K_STATE_OFF;
4284 }
Michal Kazior548db542013-07-05 16:15:15 +03004285 mutex_unlock(&ar->conf_mutex);
4286
Michal Kazior5c81c7f2014-08-05 14:54:44 +02004287 cancel_delayed_work_sync(&ar->scan.timeout);
Michal Kazioraffd3212013-07-16 09:54:35 +02004288 cancel_work_sync(&ar->restart_work);
4289}
4290
Michal Kaziorad088bf2013-10-16 15:44:46 +03004291static int ath10k_config_ps(struct ath10k *ar)
Michal Kazioraffd3212013-07-16 09:54:35 +02004292{
Michal Kaziorad088bf2013-10-16 15:44:46 +03004293 struct ath10k_vif *arvif;
4294 int ret = 0;
Michal Kazioraffd3212013-07-16 09:54:35 +02004295
4296 lockdep_assert_held(&ar->conf_mutex);
4297
Michal Kaziorad088bf2013-10-16 15:44:46 +03004298 list_for_each_entry(arvif, &ar->arvifs, list) {
4299 ret = ath10k_mac_vif_setup_ps(arvif);
4300 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004301 ath10k_warn(ar, "failed to setup powersave: %d\n", ret);
Michal Kaziorad088bf2013-10-16 15:44:46 +03004302 break;
4303 }
4304 }
Michal Kazioraffd3212013-07-16 09:54:35 +02004305
Michal Kaziorad088bf2013-10-16 15:44:46 +03004306 return ret;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004307}
4308
Michal Kazior7d9d5582014-10-21 10:40:15 +03004309static int ath10k_mac_txpower_setup(struct ath10k *ar, int txpower)
4310{
4311 int ret;
4312 u32 param;
4313
4314 lockdep_assert_held(&ar->conf_mutex);
4315
4316 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac txpower %d\n", txpower);
4317
4318 param = ar->wmi.pdev_param->txpower_limit2g;
4319 ret = ath10k_wmi_pdev_set_param(ar, param, txpower * 2);
4320 if (ret) {
4321 ath10k_warn(ar, "failed to set 2g txpower %d: %d\n",
4322 txpower, ret);
4323 return ret;
4324 }
4325
4326 param = ar->wmi.pdev_param->txpower_limit5g;
4327 ret = ath10k_wmi_pdev_set_param(ar, param, txpower * 2);
4328 if (ret) {
4329 ath10k_warn(ar, "failed to set 5g txpower %d: %d\n",
4330 txpower, ret);
4331 return ret;
4332 }
4333
4334 return 0;
4335}
4336
4337static int ath10k_mac_txpower_recalc(struct ath10k *ar)
4338{
4339 struct ath10k_vif *arvif;
4340 int ret, txpower = -1;
4341
4342 lockdep_assert_held(&ar->conf_mutex);
4343
4344 list_for_each_entry(arvif, &ar->arvifs, list) {
4345 WARN_ON(arvif->txpower < 0);
4346
4347 if (txpower == -1)
4348 txpower = arvif->txpower;
4349 else
4350 txpower = min(txpower, arvif->txpower);
4351 }
4352
4353 if (WARN_ON(txpower == -1))
4354 return -EINVAL;
4355
4356 ret = ath10k_mac_txpower_setup(ar, txpower);
4357 if (ret) {
4358 ath10k_warn(ar, "failed to setup tx power %d: %d\n",
4359 txpower, ret);
4360 return ret;
4361 }
4362
4363 return 0;
4364}
4365
Kalle Valo5e3dd152013-06-12 20:52:10 +03004366static int ath10k_config(struct ieee80211_hw *hw, u32 changed)
4367{
Kalle Valo5e3dd152013-06-12 20:52:10 +03004368 struct ath10k *ar = hw->priv;
4369 struct ieee80211_conf *conf = &hw->conf;
4370 int ret = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004371
4372 mutex_lock(&ar->conf_mutex);
4373
Michal Kazioraffd3212013-07-16 09:54:35 +02004374 if (changed & IEEE80211_CONF_CHANGE_PS)
4375 ath10k_config_ps(ar);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004376
4377 if (changed & IEEE80211_CONF_CHANGE_MONITOR) {
Michal Kazior19337472014-08-28 12:58:16 +02004378 ar->monitor = conf->flags & IEEE80211_CONF_MONITOR;
4379 ret = ath10k_monitor_recalc(ar);
4380 if (ret)
4381 ath10k_warn(ar, "failed to recalc monitor: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004382 }
4383
4384 mutex_unlock(&ar->conf_mutex);
4385 return ret;
4386}
4387
Ben Greear5572a952014-11-24 16:22:10 +02004388static u32 get_nss_from_chainmask(u16 chain_mask)
4389{
Rajkumar Manoharanf680f702015-11-03 11:51:33 +05304390 if ((chain_mask & 0xf) == 0xf)
Ben Greear5572a952014-11-24 16:22:10 +02004391 return 4;
4392 else if ((chain_mask & 0x7) == 0x7)
4393 return 3;
4394 else if ((chain_mask & 0x3) == 0x3)
4395 return 2;
4396 return 1;
4397}
4398
Vivek Natarajana48e2cc2015-08-04 10:45:12 +05304399static int ath10k_mac_set_txbf_conf(struct ath10k_vif *arvif)
4400{
4401 u32 value = 0;
4402 struct ath10k *ar = arvif->ar;
Bartosz Markowski707a0c82015-09-02 13:20:19 +02004403 int nsts;
Bartosz Markowski0c6d6f22015-09-02 13:20:20 +02004404 int sound_dim;
Vivek Natarajana48e2cc2015-08-04 10:45:12 +05304405
4406 if (ath10k_wmi_get_txbf_conf_scheme(ar) != WMI_TXBF_CONF_BEFORE_ASSOC)
4407 return 0;
4408
Bartosz Markowski707a0c82015-09-02 13:20:19 +02004409 nsts = ath10k_mac_get_vht_cap_bf_sts(ar);
Vivek Natarajana48e2cc2015-08-04 10:45:12 +05304410 if (ar->vht_cap_info & (IEEE80211_VHT_CAP_SU_BEAMFORMEE_CAPABLE |
4411 IEEE80211_VHT_CAP_MU_BEAMFORMEE_CAPABLE))
Bartosz Markowski707a0c82015-09-02 13:20:19 +02004412 value |= SM(nsts, WMI_TXBF_STS_CAP_OFFSET);
Vivek Natarajana48e2cc2015-08-04 10:45:12 +05304413
Bartosz Markowski0c6d6f22015-09-02 13:20:20 +02004414 sound_dim = ath10k_mac_get_vht_cap_bf_sound_dim(ar);
Vivek Natarajana48e2cc2015-08-04 10:45:12 +05304415 if (ar->vht_cap_info & (IEEE80211_VHT_CAP_SU_BEAMFORMER_CAPABLE |
4416 IEEE80211_VHT_CAP_MU_BEAMFORMER_CAPABLE))
Bartosz Markowski0c6d6f22015-09-02 13:20:20 +02004417 value |= SM(sound_dim, WMI_BF_SOUND_DIM_OFFSET);
Vivek Natarajana48e2cc2015-08-04 10:45:12 +05304418
4419 if (!value)
4420 return 0;
4421
4422 if (ar->vht_cap_info & IEEE80211_VHT_CAP_SU_BEAMFORMER_CAPABLE)
4423 value |= WMI_VDEV_PARAM_TXBF_SU_TX_BFER;
4424
4425 if (ar->vht_cap_info & IEEE80211_VHT_CAP_MU_BEAMFORMER_CAPABLE)
4426 value |= (WMI_VDEV_PARAM_TXBF_MU_TX_BFER |
4427 WMI_VDEV_PARAM_TXBF_SU_TX_BFER);
4428
4429 if (ar->vht_cap_info & IEEE80211_VHT_CAP_SU_BEAMFORMEE_CAPABLE)
4430 value |= WMI_VDEV_PARAM_TXBF_SU_TX_BFEE;
4431
4432 if (ar->vht_cap_info & IEEE80211_VHT_CAP_MU_BEAMFORMEE_CAPABLE)
4433 value |= (WMI_VDEV_PARAM_TXBF_MU_TX_BFEE |
4434 WMI_VDEV_PARAM_TXBF_SU_TX_BFEE);
4435
4436 return ath10k_wmi_vdev_set_param(ar, arvif->vdev_id,
4437 ar->wmi.vdev_param->txbf, value);
4438}
4439
Kalle Valo5e3dd152013-06-12 20:52:10 +03004440/*
4441 * TODO:
4442 * Figure out how to handle WMI_VDEV_SUBTYPE_P2P_DEVICE,
4443 * because we will send mgmt frames without CCK. This requirement
4444 * for P2P_FIND/GO_NEG should be handled by checking CCK flag
4445 * in the TX packet.
4446 */
4447static int ath10k_add_interface(struct ieee80211_hw *hw,
4448 struct ieee80211_vif *vif)
4449{
4450 struct ath10k *ar = hw->priv;
4451 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kaziorbb8f0c62016-03-06 16:14:27 +02004452 struct ath10k_peer *peer;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004453 enum wmi_sta_powersave_param param;
4454 int ret = 0;
Kalle Valo5a13e762014-01-20 11:01:46 +02004455 u32 value;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004456 int bit;
Michal Kazior96d828d2015-03-31 10:26:23 +00004457 int i;
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02004458 u32 vdev_param;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004459
Johannes Berg848955c2014-11-11 12:48:42 +01004460 vif->driver_flags |= IEEE80211_VIF_SUPPORTS_UAPSD;
4461
Kalle Valo5e3dd152013-06-12 20:52:10 +03004462 mutex_lock(&ar->conf_mutex);
4463
Michal Kazior0dbd09e2013-07-31 10:55:14 +02004464 memset(arvif, 0, sizeof(*arvif));
4465
Kalle Valo5e3dd152013-06-12 20:52:10 +03004466 arvif->ar = ar;
4467 arvif->vif = vif;
4468
Ben Greeare63b33f2013-10-22 14:54:14 -07004469 INIT_LIST_HEAD(&arvif->list);
Michal Kazior81a9a172015-03-05 16:02:17 +02004470 INIT_WORK(&arvif->ap_csa_work, ath10k_mac_vif_ap_csa_work);
Michal Kaziorcc9904e2015-03-10 16:22:01 +02004471 INIT_DELAYED_WORK(&arvif->connection_loss_work,
4472 ath10k_mac_vif_sta_connection_loss_work);
Michal Kaziorcc4827b2013-10-16 15:44:45 +03004473
Michal Kazior45c9abc2015-04-21 20:42:58 +03004474 for (i = 0; i < ARRAY_SIZE(arvif->bitrate_mask.control); i++) {
4475 arvif->bitrate_mask.control[i].legacy = 0xffffffff;
4476 memset(arvif->bitrate_mask.control[i].ht_mcs, 0xff,
4477 sizeof(arvif->bitrate_mask.control[i].ht_mcs));
4478 memset(arvif->bitrate_mask.control[i].vht_mcs, 0xff,
4479 sizeof(arvif->bitrate_mask.control[i].vht_mcs));
4480 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004481
Michal Kaziore04cafb2015-08-05 12:15:24 +02004482 if (ar->num_peers >= ar->max_num_peers) {
4483 ath10k_warn(ar, "refusing vdev creation due to insufficient peer entry resources in firmware\n");
Michal Kazior503422d2015-08-19 13:08:53 +02004484 ret = -ENOBUFS;
4485 goto err;
Michal Kaziore04cafb2015-08-05 12:15:24 +02004486 }
4487
Ben Greeara9aefb32014-08-12 11:02:19 +03004488 if (ar->free_vdev_map == 0) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004489 ath10k_warn(ar, "Free vdev map is empty, no more interfaces allowed.\n");
Kalle Valo5e3dd152013-06-12 20:52:10 +03004490 ret = -EBUSY;
Michal Kazior9dad14a2013-10-16 15:44:45 +03004491 goto err;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004492 }
Ben Greear16c11172014-09-23 14:17:16 -07004493 bit = __ffs64(ar->free_vdev_map);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004494
Ben Greear16c11172014-09-23 14:17:16 -07004495 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac create vdev %i map %llx\n",
4496 bit, ar->free_vdev_map);
4497
4498 arvif->vdev_id = bit;
Peter Oh6e4de1a2016-01-28 13:54:10 -08004499 arvif->vdev_subtype =
4500 ath10k_wmi_get_vdev_subtype(ar, WMI_VDEV_SUBTYPE_NONE);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004501
Kalle Valo5e3dd152013-06-12 20:52:10 +03004502 switch (vif->type) {
Michal Kazior75d2bd42014-12-12 12:41:39 +01004503 case NL80211_IFTYPE_P2P_DEVICE:
4504 arvif->vdev_type = WMI_VDEV_TYPE_STA;
Peter Oh6e4de1a2016-01-28 13:54:10 -08004505 arvif->vdev_subtype = ath10k_wmi_get_vdev_subtype
4506 (ar, WMI_VDEV_SUBTYPE_P2P_DEVICE);
Michal Kazior75d2bd42014-12-12 12:41:39 +01004507 break;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004508 case NL80211_IFTYPE_UNSPECIFIED:
4509 case NL80211_IFTYPE_STATION:
4510 arvif->vdev_type = WMI_VDEV_TYPE_STA;
4511 if (vif->p2p)
Peter Oh6e4de1a2016-01-28 13:54:10 -08004512 arvif->vdev_subtype = ath10k_wmi_get_vdev_subtype
4513 (ar, WMI_VDEV_SUBTYPE_P2P_CLIENT);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004514 break;
4515 case NL80211_IFTYPE_ADHOC:
4516 arvif->vdev_type = WMI_VDEV_TYPE_IBSS;
4517 break;
Bob Copelandb6c7baf2015-09-09 12:47:36 -04004518 case NL80211_IFTYPE_MESH_POINT:
Peter Oh0b3d76e2016-01-28 13:54:07 -08004519 if (test_bit(WMI_SERVICE_MESH_11S, ar->wmi.svc_map)) {
Peter Oh6e4de1a2016-01-28 13:54:10 -08004520 arvif->vdev_subtype = ath10k_wmi_get_vdev_subtype
4521 (ar, WMI_VDEV_SUBTYPE_MESH_11S);
Peter Ohbb58b892015-11-24 09:37:35 -08004522 } else if (!test_bit(ATH10K_FLAG_RAW_MODE, &ar->dev_flags)) {
Bob Copelandb6c7baf2015-09-09 12:47:36 -04004523 ret = -EINVAL;
4524 ath10k_warn(ar, "must load driver with rawmode=1 to add mesh interfaces\n");
4525 goto err;
4526 }
4527 arvif->vdev_type = WMI_VDEV_TYPE_AP;
4528 break;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004529 case NL80211_IFTYPE_AP:
4530 arvif->vdev_type = WMI_VDEV_TYPE_AP;
4531
4532 if (vif->p2p)
Peter Oh6e4de1a2016-01-28 13:54:10 -08004533 arvif->vdev_subtype = ath10k_wmi_get_vdev_subtype
4534 (ar, WMI_VDEV_SUBTYPE_P2P_GO);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004535 break;
4536 case NL80211_IFTYPE_MONITOR:
4537 arvif->vdev_type = WMI_VDEV_TYPE_MONITOR;
4538 break;
4539 default:
4540 WARN_ON(1);
4541 break;
4542 }
4543
Michal Kazior96d828d2015-03-31 10:26:23 +00004544 /* Using vdev_id as queue number will make it very easy to do per-vif
4545 * tx queue locking. This shouldn't wrap due to interface combinations
4546 * but do a modulo for correctness sake and prevent using offchannel tx
4547 * queues for regular vif tx.
4548 */
4549 vif->cab_queue = arvif->vdev_id % (IEEE80211_MAX_QUEUES - 1);
4550 for (i = 0; i < ARRAY_SIZE(vif->hw_queue); i++)
4551 vif->hw_queue[i] = arvif->vdev_id % (IEEE80211_MAX_QUEUES - 1);
4552
Michal Kazior64badcb2014-09-18 11:18:02 +03004553 /* Some firmware revisions don't wait for beacon tx completion before
4554 * sending another SWBA event. This could lead to hardware using old
4555 * (freed) beacon data in some cases, e.g. tx credit starvation
4556 * combined with missed TBTT. This is very very rare.
4557 *
4558 * On non-IOMMU-enabled hosts this could be a possible security issue
4559 * because hw could beacon some random data on the air. On
4560 * IOMMU-enabled hosts DMAR faults would occur in most cases and target
4561 * device would crash.
4562 *
4563 * Since there are no beacon tx completions (implicit nor explicit)
4564 * propagated to host the only workaround for this is to allocate a
4565 * DMA-coherent buffer for a lifetime of a vif and use it for all
4566 * beacon tx commands. Worst case for this approach is some beacons may
4567 * become corrupted, e.g. have garbled IEs or out-of-date TIM bitmap.
4568 */
4569 if (vif->type == NL80211_IFTYPE_ADHOC ||
Bob Copelandb6c7baf2015-09-09 12:47:36 -04004570 vif->type == NL80211_IFTYPE_MESH_POINT ||
Michal Kazior64badcb2014-09-18 11:18:02 +03004571 vif->type == NL80211_IFTYPE_AP) {
4572 arvif->beacon_buf = dma_zalloc_coherent(ar->dev,
4573 IEEE80211_MAX_FRAME_LEN,
4574 &arvif->beacon_paddr,
Rajkumar Manoharan82d7aba2014-10-10 17:38:27 +05304575 GFP_ATOMIC);
Michal Kazior64badcb2014-09-18 11:18:02 +03004576 if (!arvif->beacon_buf) {
4577 ret = -ENOMEM;
4578 ath10k_warn(ar, "failed to allocate beacon buffer: %d\n",
4579 ret);
4580 goto err;
4581 }
4582 }
David Liuccec9032015-07-24 20:25:32 +03004583 if (test_bit(ATH10K_FLAG_HW_CRYPTO_DISABLED, &ar->dev_flags))
4584 arvif->nohwcrypt = true;
4585
4586 if (arvif->nohwcrypt &&
4587 !test_bit(ATH10K_FLAG_RAW_MODE, &ar->dev_flags)) {
4588 ath10k_warn(ar, "cryptmode module param needed for sw crypto\n");
4589 goto err;
4590 }
Michal Kazior64badcb2014-09-18 11:18:02 +03004591
4592 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev create %d (add interface) type %d subtype %d bcnmode %s\n",
4593 arvif->vdev_id, arvif->vdev_type, arvif->vdev_subtype,
4594 arvif->beacon_buf ? "single-buf" : "per-skb");
Kalle Valo5e3dd152013-06-12 20:52:10 +03004595
4596 ret = ath10k_wmi_vdev_create(ar, arvif->vdev_id, arvif->vdev_type,
4597 arvif->vdev_subtype, vif->addr);
4598 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004599 ath10k_warn(ar, "failed to create WMI vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004600 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004601 goto err;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004602 }
4603
Ben Greear16c11172014-09-23 14:17:16 -07004604 ar->free_vdev_map &= ~(1LL << arvif->vdev_id);
Michal Kazior05791192013-10-16 15:44:45 +03004605 list_add(&arvif->list, &ar->arvifs);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004606
Michal Kazior46725b152015-01-28 09:57:49 +02004607 /* It makes no sense to have firmware do keepalives. mac80211 already
4608 * takes care of this with idle connection polling.
4609 */
4610 ret = ath10k_mac_vif_disable_keepalive(arvif);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004611 if (ret) {
Michal Kazior46725b152015-01-28 09:57:49 +02004612 ath10k_warn(ar, "failed to disable keepalive on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004613 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004614 goto err_vdev_delete;
4615 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004616
SenthilKumar Jegadeesan627613f2015-01-29 13:50:38 +02004617 arvif->def_wep_key_idx = -1;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004618
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02004619 vdev_param = ar->wmi.vdev_param->tx_encap_type;
4620 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03004621 ATH10K_HW_TXRX_NATIVE_WIFI);
Bartosz Markowskiebc9abd2013-10-15 09:26:20 +02004622 /* 10.X firmware does not support this VDEV parameter. Do not warn */
Michal Kazior9dad14a2013-10-16 15:44:45 +03004623 if (ret && ret != -EOPNOTSUPP) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004624 ath10k_warn(ar, "failed to set vdev %i TX encapsulation: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004625 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004626 goto err_vdev_delete;
4627 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004628
Ben Greear5572a952014-11-24 16:22:10 +02004629 if (ar->cfg_tx_chainmask) {
4630 u16 nss = get_nss_from_chainmask(ar->cfg_tx_chainmask);
4631
4632 vdev_param = ar->wmi.vdev_param->nss;
4633 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
4634 nss);
4635 if (ret) {
4636 ath10k_warn(ar, "failed to set vdev %i chainmask 0x%x, nss %i: %d\n",
4637 arvif->vdev_id, ar->cfg_tx_chainmask, nss,
4638 ret);
4639 goto err_vdev_delete;
4640 }
4641 }
4642
Michal Kaziore57e0572015-03-24 13:14:03 +00004643 if (arvif->vdev_type == WMI_VDEV_TYPE_AP ||
4644 arvif->vdev_type == WMI_VDEV_TYPE_IBSS) {
Michal Kazior69427262016-03-06 16:14:30 +02004645 ret = ath10k_peer_create(ar, vif, NULL, arvif->vdev_id,
4646 vif->addr, WMI_PEER_TYPE_DEFAULT);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004647 if (ret) {
Michal Kaziore57e0572015-03-24 13:14:03 +00004648 ath10k_warn(ar, "failed to create vdev %i peer for AP/IBSS: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004649 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004650 goto err_vdev_delete;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004651 }
Michal Kaziorbb8f0c62016-03-06 16:14:27 +02004652
4653 spin_lock_bh(&ar->data_lock);
4654
4655 peer = ath10k_peer_find(ar, arvif->vdev_id, vif->addr);
4656 if (!peer) {
4657 ath10k_warn(ar, "failed to lookup peer %pM on vdev %i\n",
4658 vif->addr, arvif->vdev_id);
4659 spin_unlock_bh(&ar->data_lock);
4660 ret = -ENOENT;
4661 goto err_peer_delete;
4662 }
4663
4664 arvif->peer_id = find_first_bit(peer->peer_ids,
4665 ATH10K_MAX_NUM_PEER_IDS);
4666
4667 spin_unlock_bh(&ar->data_lock);
4668 } else {
4669 arvif->peer_id = HTT_INVALID_PEERID;
Michal Kaziore57e0572015-03-24 13:14:03 +00004670 }
Marek Puzyniakcdf07402013-12-30 09:07:51 +01004671
Michal Kaziore57e0572015-03-24 13:14:03 +00004672 if (arvif->vdev_type == WMI_VDEV_TYPE_AP) {
Kalle Valo5a13e762014-01-20 11:01:46 +02004673 ret = ath10k_mac_set_kickout(arvif);
4674 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004675 ath10k_warn(ar, "failed to set vdev %i kickout parameters: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004676 arvif->vdev_id, ret);
Kalle Valo5a13e762014-01-20 11:01:46 +02004677 goto err_peer_delete;
4678 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004679 }
4680
4681 if (arvif->vdev_type == WMI_VDEV_TYPE_STA) {
4682 param = WMI_STA_PS_PARAM_RX_WAKE_POLICY;
4683 value = WMI_STA_PS_RX_WAKE_POLICY_WAKE;
4684 ret = ath10k_wmi_set_sta_ps_param(ar, arvif->vdev_id,
4685 param, value);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004686 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004687 ath10k_warn(ar, "failed to set vdev %i RX wake policy: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004688 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004689 goto err_peer_delete;
4690 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004691
Michal Kazior9f9b5742014-12-12 12:41:36 +01004692 ret = ath10k_mac_vif_recalc_ps_wake_threshold(arvif);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004693 if (ret) {
Michal Kazior9f9b5742014-12-12 12:41:36 +01004694 ath10k_warn(ar, "failed to recalc ps wake threshold on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004695 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004696 goto err_peer_delete;
4697 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004698
Michal Kazior9f9b5742014-12-12 12:41:36 +01004699 ret = ath10k_mac_vif_recalc_ps_poll_count(arvif);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004700 if (ret) {
Michal Kazior9f9b5742014-12-12 12:41:36 +01004701 ath10k_warn(ar, "failed to recalc ps poll count on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004702 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004703 goto err_peer_delete;
4704 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004705 }
4706
Vivek Natarajana48e2cc2015-08-04 10:45:12 +05304707 ret = ath10k_mac_set_txbf_conf(arvif);
4708 if (ret) {
4709 ath10k_warn(ar, "failed to set txbf for vdev %d: %d\n",
4710 arvif->vdev_id, ret);
4711 goto err_peer_delete;
4712 }
4713
Michal Kazior424121c2013-07-22 14:13:31 +02004714 ret = ath10k_mac_set_rts(arvif, ar->hw->wiphy->rts_threshold);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004715 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004716 ath10k_warn(ar, "failed to set rts threshold for vdev %d: %d\n",
Michal Kazior679c54a2013-07-05 16:15:04 +03004717 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004718 goto err_peer_delete;
4719 }
Michal Kazior679c54a2013-07-05 16:15:04 +03004720
Michal Kazior7d9d5582014-10-21 10:40:15 +03004721 arvif->txpower = vif->bss_conf.txpower;
4722 ret = ath10k_mac_txpower_recalc(ar);
4723 if (ret) {
4724 ath10k_warn(ar, "failed to recalc tx power: %d\n", ret);
4725 goto err_peer_delete;
4726 }
4727
Michal Kazior500ff9f2015-03-31 10:26:21 +00004728 if (vif->type == NL80211_IFTYPE_MONITOR) {
4729 ar->monitor_arvif = arvif;
4730 ret = ath10k_monitor_recalc(ar);
4731 if (ret) {
4732 ath10k_warn(ar, "failed to recalc monitor: %d\n", ret);
4733 goto err_peer_delete;
4734 }
4735 }
4736
Michal Kazior6d2d51e2015-08-07 09:08:21 +02004737 spin_lock_bh(&ar->htt.tx_lock);
4738 if (!ar->tx_paused)
4739 ieee80211_wake_queue(ar->hw, arvif->vdev_id);
4740 spin_unlock_bh(&ar->htt.tx_lock);
4741
Kalle Valo5e3dd152013-06-12 20:52:10 +03004742 mutex_unlock(&ar->conf_mutex);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004743 return 0;
4744
4745err_peer_delete:
Michal Kaziore57e0572015-03-24 13:14:03 +00004746 if (arvif->vdev_type == WMI_VDEV_TYPE_AP ||
4747 arvif->vdev_type == WMI_VDEV_TYPE_IBSS)
Michal Kazior9dad14a2013-10-16 15:44:45 +03004748 ath10k_wmi_peer_delete(ar, arvif->vdev_id, vif->addr);
4749
4750err_vdev_delete:
4751 ath10k_wmi_vdev_delete(ar, arvif->vdev_id);
Ben Greear16c11172014-09-23 14:17:16 -07004752 ar->free_vdev_map |= 1LL << arvif->vdev_id;
Michal Kazior05791192013-10-16 15:44:45 +03004753 list_del(&arvif->list);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004754
4755err:
Michal Kazior64badcb2014-09-18 11:18:02 +03004756 if (arvif->beacon_buf) {
4757 dma_free_coherent(ar->dev, IEEE80211_MAX_FRAME_LEN,
4758 arvif->beacon_buf, arvif->beacon_paddr);
4759 arvif->beacon_buf = NULL;
4760 }
4761
Michal Kazior9dad14a2013-10-16 15:44:45 +03004762 mutex_unlock(&ar->conf_mutex);
4763
Kalle Valo5e3dd152013-06-12 20:52:10 +03004764 return ret;
4765}
4766
Michal Kaziorb4aa5392015-03-31 10:26:24 +00004767static void ath10k_mac_vif_tx_unlock_all(struct ath10k_vif *arvif)
4768{
4769 int i;
4770
4771 for (i = 0; i < BITS_PER_LONG; i++)
4772 ath10k_mac_vif_tx_unlock(arvif, i);
4773}
4774
Kalle Valo5e3dd152013-06-12 20:52:10 +03004775static void ath10k_remove_interface(struct ieee80211_hw *hw,
4776 struct ieee80211_vif *vif)
4777{
4778 struct ath10k *ar = hw->priv;
4779 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kazior69427262016-03-06 16:14:30 +02004780 struct ath10k_peer *peer;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004781 int ret;
Michal Kazior69427262016-03-06 16:14:30 +02004782 int i;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004783
Michal Kazior81a9a172015-03-05 16:02:17 +02004784 cancel_work_sync(&arvif->ap_csa_work);
Michal Kaziorcc9904e2015-03-10 16:22:01 +02004785 cancel_delayed_work_sync(&arvif->connection_loss_work);
Michal Kazior81a9a172015-03-05 16:02:17 +02004786
Sujith Manoharan5d011f52014-11-25 11:47:00 +05304787 mutex_lock(&ar->conf_mutex);
4788
Michal Kaziored543882013-09-13 14:16:56 +02004789 spin_lock_bh(&ar->data_lock);
Michal Kazior64badcb2014-09-18 11:18:02 +03004790 ath10k_mac_vif_beacon_cleanup(arvif);
Michal Kaziored543882013-09-13 14:16:56 +02004791 spin_unlock_bh(&ar->data_lock);
4792
Simon Wunderlich855aed12014-08-02 09:12:54 +03004793 ret = ath10k_spectral_vif_stop(arvif);
4794 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02004795 ath10k_warn(ar, "failed to stop spectral for vdev %i: %d\n",
Simon Wunderlich855aed12014-08-02 09:12:54 +03004796 arvif->vdev_id, ret);
4797
Ben Greear16c11172014-09-23 14:17:16 -07004798 ar->free_vdev_map |= 1LL << arvif->vdev_id;
Michal Kazior05791192013-10-16 15:44:45 +03004799 list_del(&arvif->list);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004800
Michal Kaziore57e0572015-03-24 13:14:03 +00004801 if (arvif->vdev_type == WMI_VDEV_TYPE_AP ||
4802 arvif->vdev_type == WMI_VDEV_TYPE_IBSS) {
Michal Kazior2c512052015-02-15 16:50:40 +02004803 ret = ath10k_wmi_peer_delete(arvif->ar, arvif->vdev_id,
4804 vif->addr);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004805 if (ret)
Michal Kaziore57e0572015-03-24 13:14:03 +00004806 ath10k_warn(ar, "failed to submit AP/IBSS self-peer removal on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004807 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004808
4809 kfree(arvif->u.ap.noa_data);
4810 }
4811
Michal Kazior7aa7a722014-08-25 12:09:38 +02004812 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %i delete (remove interface)\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03004813 arvif->vdev_id);
4814
Kalle Valo5e3dd152013-06-12 20:52:10 +03004815 ret = ath10k_wmi_vdev_delete(ar, arvif->vdev_id);
4816 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02004817 ath10k_warn(ar, "failed to delete WMI vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004818 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004819
Michal Kazior2c512052015-02-15 16:50:40 +02004820 /* Some firmware revisions don't notify host about self-peer removal
4821 * until after associated vdev is deleted.
4822 */
Michal Kaziore57e0572015-03-24 13:14:03 +00004823 if (arvif->vdev_type == WMI_VDEV_TYPE_AP ||
4824 arvif->vdev_type == WMI_VDEV_TYPE_IBSS) {
Michal Kazior2c512052015-02-15 16:50:40 +02004825 ret = ath10k_wait_for_peer_deleted(ar, arvif->vdev_id,
4826 vif->addr);
4827 if (ret)
4828 ath10k_warn(ar, "failed to remove AP self-peer on vdev %i: %d\n",
4829 arvif->vdev_id, ret);
4830
4831 spin_lock_bh(&ar->data_lock);
4832 ar->num_peers--;
4833 spin_unlock_bh(&ar->data_lock);
4834 }
4835
Michal Kazior69427262016-03-06 16:14:30 +02004836 spin_lock_bh(&ar->data_lock);
4837 for (i = 0; i < ARRAY_SIZE(ar->peer_map); i++) {
4838 peer = ar->peer_map[i];
4839 if (!peer)
4840 continue;
4841
4842 if (peer->vif == vif) {
4843 ath10k_warn(ar, "found vif peer %pM entry on vdev %i after it was supposedly removed\n",
4844 vif->addr, arvif->vdev_id);
4845 peer->vif = NULL;
4846 }
4847 }
4848 spin_unlock_bh(&ar->data_lock);
4849
Kalle Valo5e3dd152013-06-12 20:52:10 +03004850 ath10k_peer_cleanup(ar, arvif->vdev_id);
4851
Michal Kazior500ff9f2015-03-31 10:26:21 +00004852 if (vif->type == NL80211_IFTYPE_MONITOR) {
4853 ar->monitor_arvif = NULL;
4854 ret = ath10k_monitor_recalc(ar);
4855 if (ret)
4856 ath10k_warn(ar, "failed to recalc monitor: %d\n", ret);
4857 }
4858
Michal Kaziorb4aa5392015-03-31 10:26:24 +00004859 spin_lock_bh(&ar->htt.tx_lock);
4860 ath10k_mac_vif_tx_unlock_all(arvif);
4861 spin_unlock_bh(&ar->htt.tx_lock);
4862
Kalle Valo5e3dd152013-06-12 20:52:10 +03004863 mutex_unlock(&ar->conf_mutex);
4864}
4865
4866/*
4867 * FIXME: Has to be verified.
4868 */
4869#define SUPPORTED_FILTERS \
Johannes Bergdf140462015-04-22 14:40:58 +02004870 (FIF_ALLMULTI | \
Kalle Valo5e3dd152013-06-12 20:52:10 +03004871 FIF_CONTROL | \
4872 FIF_PSPOLL | \
4873 FIF_OTHER_BSS | \
4874 FIF_BCN_PRBRESP_PROMISC | \
4875 FIF_PROBE_REQ | \
4876 FIF_FCSFAIL)
4877
4878static void ath10k_configure_filter(struct ieee80211_hw *hw,
4879 unsigned int changed_flags,
4880 unsigned int *total_flags,
4881 u64 multicast)
4882{
4883 struct ath10k *ar = hw->priv;
4884 int ret;
4885
4886 mutex_lock(&ar->conf_mutex);
4887
4888 changed_flags &= SUPPORTED_FILTERS;
4889 *total_flags &= SUPPORTED_FILTERS;
4890 ar->filter_flags = *total_flags;
4891
Michal Kazior19337472014-08-28 12:58:16 +02004892 ret = ath10k_monitor_recalc(ar);
4893 if (ret)
4894 ath10k_warn(ar, "failed to recalc montior: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004895
4896 mutex_unlock(&ar->conf_mutex);
4897}
4898
4899static void ath10k_bss_info_changed(struct ieee80211_hw *hw,
4900 struct ieee80211_vif *vif,
4901 struct ieee80211_bss_conf *info,
4902 u32 changed)
4903{
4904 struct ath10k *ar = hw->priv;
4905 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
4906 int ret = 0;
Kalle Valoaf762c02014-09-14 12:50:17 +03004907 u32 vdev_param, pdev_param, slottime, preamble;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004908
4909 mutex_lock(&ar->conf_mutex);
4910
4911 if (changed & BSS_CHANGED_IBSS)
4912 ath10k_control_ibss(arvif, info, vif->addr);
4913
4914 if (changed & BSS_CHANGED_BEACON_INT) {
4915 arvif->beacon_interval = info->beacon_int;
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02004916 vdev_param = ar->wmi.vdev_param->beacon_interval;
4917 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03004918 arvif->beacon_interval);
Michal Kazior7aa7a722014-08-25 12:09:38 +02004919 ath10k_dbg(ar, ATH10K_DBG_MAC,
Kalle Valo60c3daa2013-09-08 17:56:07 +03004920 "mac vdev %d beacon_interval %d\n",
4921 arvif->vdev_id, arvif->beacon_interval);
4922
Kalle Valo5e3dd152013-06-12 20:52:10 +03004923 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02004924 ath10k_warn(ar, "failed to set beacon interval for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02004925 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004926 }
4927
4928 if (changed & BSS_CHANGED_BEACON) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004929 ath10k_dbg(ar, ATH10K_DBG_MAC,
Kalle Valo60c3daa2013-09-08 17:56:07 +03004930 "vdev %d set beacon tx mode to staggered\n",
4931 arvif->vdev_id);
4932
Bartosz Markowski226a3392013-09-26 17:47:16 +02004933 pdev_param = ar->wmi.pdev_param->beacon_tx_mode;
4934 ret = ath10k_wmi_pdev_set_param(ar, pdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03004935 WMI_BEACON_STAGGERED_MODE);
4936 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02004937 ath10k_warn(ar, "failed to set beacon mode for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02004938 arvif->vdev_id, ret);
Michal Kaziorfbb8f1b2015-01-13 16:30:12 +02004939
4940 ret = ath10k_mac_setup_bcn_tmpl(arvif);
4941 if (ret)
4942 ath10k_warn(ar, "failed to update beacon template: %d\n",
4943 ret);
Bob Copelandb6c7baf2015-09-09 12:47:36 -04004944
4945 if (ieee80211_vif_is_mesh(vif)) {
4946 /* mesh doesn't use SSID but firmware needs it */
4947 strncpy(arvif->u.ap.ssid, "mesh",
4948 sizeof(arvif->u.ap.ssid));
4949 arvif->u.ap.ssid_len = 4;
4950 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004951 }
4952
Michal Kaziorfbb8f1b2015-01-13 16:30:12 +02004953 if (changed & BSS_CHANGED_AP_PROBE_RESP) {
4954 ret = ath10k_mac_setup_prb_tmpl(arvif);
4955 if (ret)
4956 ath10k_warn(ar, "failed to setup probe resp template on vdev %i: %d\n",
4957 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004958 }
4959
Michal Kaziorba2479f2015-01-24 12:14:51 +02004960 if (changed & (BSS_CHANGED_BEACON_INFO | BSS_CHANGED_BEACON)) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03004961 arvif->dtim_period = info->dtim_period;
4962
Michal Kazior7aa7a722014-08-25 12:09:38 +02004963 ath10k_dbg(ar, ATH10K_DBG_MAC,
Kalle Valo60c3daa2013-09-08 17:56:07 +03004964 "mac vdev %d dtim_period %d\n",
4965 arvif->vdev_id, arvif->dtim_period);
4966
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02004967 vdev_param = ar->wmi.vdev_param->dtim_period;
4968 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03004969 arvif->dtim_period);
4970 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02004971 ath10k_warn(ar, "failed to set dtim period for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02004972 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004973 }
4974
4975 if (changed & BSS_CHANGED_SSID &&
4976 vif->type == NL80211_IFTYPE_AP) {
4977 arvif->u.ap.ssid_len = info->ssid_len;
4978 if (info->ssid_len)
4979 memcpy(arvif->u.ap.ssid, info->ssid, info->ssid_len);
4980 arvif->u.ap.hidden_ssid = info->hidden_ssid;
4981 }
4982
Michal Kazior077efc82014-10-21 10:10:29 +03004983 if (changed & BSS_CHANGED_BSSID && !is_zero_ether_addr(info->bssid))
4984 ether_addr_copy(arvif->bssid, info->bssid);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004985
4986 if (changed & BSS_CHANGED_BEACON_ENABLED)
4987 ath10k_control_beaconing(arvif, info);
4988
4989 if (changed & BSS_CHANGED_ERP_CTS_PROT) {
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02004990 arvif->use_cts_prot = info->use_cts_prot;
Michal Kazior7aa7a722014-08-25 12:09:38 +02004991 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %d cts_prot %d\n",
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02004992 arvif->vdev_id, info->use_cts_prot);
Kalle Valo60c3daa2013-09-08 17:56:07 +03004993
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02004994 ret = ath10k_recalc_rtscts_prot(arvif);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004995 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02004996 ath10k_warn(ar, "failed to recalculate rts/cts prot for vdev %d: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004997 arvif->vdev_id, ret);
Michal Kaziora87fd4b2015-03-02 11:21:17 +01004998
4999 vdev_param = ar->wmi.vdev_param->protection_mode;
5000 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
5001 info->use_cts_prot ? 1 : 0);
5002 if (ret)
5003 ath10k_warn(ar, "failed to set protection mode %d on vdev %i: %d\n",
Kalle Valo617b0f42015-10-05 17:56:35 +03005004 info->use_cts_prot, arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005005 }
5006
5007 if (changed & BSS_CHANGED_ERP_SLOT) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03005008 if (info->use_short_slot)
5009 slottime = WMI_VDEV_SLOT_TIME_SHORT; /* 9us */
5010
5011 else
5012 slottime = WMI_VDEV_SLOT_TIME_LONG; /* 20us */
5013
Michal Kazior7aa7a722014-08-25 12:09:38 +02005014 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %d slot_time %d\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03005015 arvif->vdev_id, slottime);
5016
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02005017 vdev_param = ar->wmi.vdev_param->slot_time;
5018 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03005019 slottime);
5020 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005021 ath10k_warn(ar, "failed to set erp slot for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02005022 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005023 }
5024
5025 if (changed & BSS_CHANGED_ERP_PREAMBLE) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03005026 if (info->use_short_preamble)
5027 preamble = WMI_VDEV_PREAMBLE_SHORT;
5028 else
5029 preamble = WMI_VDEV_PREAMBLE_LONG;
5030
Michal Kazior7aa7a722014-08-25 12:09:38 +02005031 ath10k_dbg(ar, ATH10K_DBG_MAC,
Kalle Valo60c3daa2013-09-08 17:56:07 +03005032 "mac vdev %d preamble %dn",
5033 arvif->vdev_id, preamble);
5034
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02005035 vdev_param = ar->wmi.vdev_param->preamble;
5036 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03005037 preamble);
5038 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005039 ath10k_warn(ar, "failed to set preamble for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02005040 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005041 }
5042
5043 if (changed & BSS_CHANGED_ASSOC) {
Michal Kaziore556f112014-08-28 12:58:17 +02005044 if (info->assoc) {
5045 /* Workaround: Make sure monitor vdev is not running
5046 * when associating to prevent some firmware revisions
5047 * (e.g. 10.1 and 10.2) from crashing.
5048 */
5049 if (ar->monitor_started)
5050 ath10k_monitor_stop(ar);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005051 ath10k_bss_assoc(hw, vif, info);
Michal Kaziore556f112014-08-28 12:58:17 +02005052 ath10k_monitor_recalc(ar);
Michal Kazior077efc82014-10-21 10:10:29 +03005053 } else {
5054 ath10k_bss_disassoc(hw, vif);
Michal Kaziore556f112014-08-28 12:58:17 +02005055 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03005056 }
5057
Michal Kazior7d9d5582014-10-21 10:40:15 +03005058 if (changed & BSS_CHANGED_TXPOWER) {
5059 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev_id %i txpower %d\n",
5060 arvif->vdev_id, info->txpower);
5061
5062 arvif->txpower = info->txpower;
5063 ret = ath10k_mac_txpower_recalc(ar);
5064 if (ret)
5065 ath10k_warn(ar, "failed to recalc tx power: %d\n", ret);
5066 }
5067
Michal Kaziorbf14e652014-12-12 12:41:38 +01005068 if (changed & BSS_CHANGED_PS) {
Michal Kaziorcffb41f2015-02-13 13:30:16 +01005069 arvif->ps = vif->bss_conf.ps;
5070
5071 ret = ath10k_config_ps(ar);
Michal Kaziorbf14e652014-12-12 12:41:38 +01005072 if (ret)
5073 ath10k_warn(ar, "failed to setup ps on vdev %i: %d\n",
5074 arvif->vdev_id, ret);
5075 }
5076
Kalle Valo5e3dd152013-06-12 20:52:10 +03005077 mutex_unlock(&ar->conf_mutex);
5078}
5079
5080static int ath10k_hw_scan(struct ieee80211_hw *hw,
5081 struct ieee80211_vif *vif,
David Spinadelc56ef672014-02-05 15:21:13 +02005082 struct ieee80211_scan_request *hw_req)
Kalle Valo5e3dd152013-06-12 20:52:10 +03005083{
5084 struct ath10k *ar = hw->priv;
5085 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
David Spinadelc56ef672014-02-05 15:21:13 +02005086 struct cfg80211_scan_request *req = &hw_req->req;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005087 struct wmi_start_scan_arg arg;
5088 int ret = 0;
5089 int i;
5090
5091 mutex_lock(&ar->conf_mutex);
5092
5093 spin_lock_bh(&ar->data_lock);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005094 switch (ar->scan.state) {
5095 case ATH10K_SCAN_IDLE:
5096 reinit_completion(&ar->scan.started);
5097 reinit_completion(&ar->scan.completed);
5098 ar->scan.state = ATH10K_SCAN_STARTING;
5099 ar->scan.is_roc = false;
5100 ar->scan.vdev_id = arvif->vdev_id;
5101 ret = 0;
5102 break;
5103 case ATH10K_SCAN_STARTING:
5104 case ATH10K_SCAN_RUNNING:
5105 case ATH10K_SCAN_ABORTING:
Kalle Valo5e3dd152013-06-12 20:52:10 +03005106 ret = -EBUSY;
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005107 break;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005108 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03005109 spin_unlock_bh(&ar->data_lock);
5110
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005111 if (ret)
5112 goto exit;
5113
Kalle Valo5e3dd152013-06-12 20:52:10 +03005114 memset(&arg, 0, sizeof(arg));
5115 ath10k_wmi_start_scan_init(ar, &arg);
5116 arg.vdev_id = arvif->vdev_id;
5117 arg.scan_id = ATH10K_SCAN_ID;
5118
Kalle Valo5e3dd152013-06-12 20:52:10 +03005119 if (req->ie_len) {
5120 arg.ie_len = req->ie_len;
5121 memcpy(arg.ie, req->ie, arg.ie_len);
5122 }
5123
5124 if (req->n_ssids) {
5125 arg.n_ssids = req->n_ssids;
5126 for (i = 0; i < arg.n_ssids; i++) {
5127 arg.ssids[i].len = req->ssids[i].ssid_len;
5128 arg.ssids[i].ssid = req->ssids[i].ssid;
5129 }
Michal Kaziordcd4a562013-07-31 10:55:12 +02005130 } else {
5131 arg.scan_ctrl_flags |= WMI_SCAN_FLAG_PASSIVE;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005132 }
5133
5134 if (req->n_channels) {
5135 arg.n_channels = req->n_channels;
5136 for (i = 0; i < arg.n_channels; i++)
5137 arg.channels[i] = req->channels[i]->center_freq;
5138 }
5139
5140 ret = ath10k_start_scan(ar, &arg);
5141 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005142 ath10k_warn(ar, "failed to start hw scan: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005143 spin_lock_bh(&ar->data_lock);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005144 ar->scan.state = ATH10K_SCAN_IDLE;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005145 spin_unlock_bh(&ar->data_lock);
5146 }
5147
Michal Kazior634349b2015-09-03 10:43:45 +02005148 /* Add a 200ms margin to account for event/command processing */
5149 ieee80211_queue_delayed_work(ar->hw, &ar->scan.timeout,
5150 msecs_to_jiffies(arg.max_scan_time +
5151 200));
5152
Kalle Valo5e3dd152013-06-12 20:52:10 +03005153exit:
5154 mutex_unlock(&ar->conf_mutex);
5155 return ret;
5156}
5157
5158static void ath10k_cancel_hw_scan(struct ieee80211_hw *hw,
5159 struct ieee80211_vif *vif)
5160{
5161 struct ath10k *ar = hw->priv;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005162
5163 mutex_lock(&ar->conf_mutex);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005164 ath10k_scan_abort(ar);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005165 mutex_unlock(&ar->conf_mutex);
Michal Kazior4eb2e162014-10-28 10:23:09 +01005166
5167 cancel_delayed_work_sync(&ar->scan.timeout);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005168}
5169
Michal Kaziorcfb27d22013-12-02 09:06:36 +01005170static void ath10k_set_key_h_def_keyidx(struct ath10k *ar,
5171 struct ath10k_vif *arvif,
5172 enum set_key_cmd cmd,
5173 struct ieee80211_key_conf *key)
5174{
5175 u32 vdev_param = arvif->ar->wmi.vdev_param->def_keyid;
5176 int ret;
5177
5178 /* 10.1 firmware branch requires default key index to be set to group
5179 * key index after installing it. Otherwise FW/HW Txes corrupted
5180 * frames with multi-vif APs. This is not required for main firmware
5181 * branch (e.g. 636).
5182 *
Michal Kazior8461baf2015-04-10 13:23:22 +00005183 * This is also needed for 636 fw for IBSS-RSN to work more reliably.
5184 *
5185 * FIXME: It remains unknown if this is required for multi-vif STA
5186 * interfaces on 10.1.
5187 */
Michal Kaziorcfb27d22013-12-02 09:06:36 +01005188
Michal Kazior8461baf2015-04-10 13:23:22 +00005189 if (arvif->vdev_type != WMI_VDEV_TYPE_AP &&
5190 arvif->vdev_type != WMI_VDEV_TYPE_IBSS)
Michal Kaziorcfb27d22013-12-02 09:06:36 +01005191 return;
5192
5193 if (key->cipher == WLAN_CIPHER_SUITE_WEP40)
5194 return;
5195
5196 if (key->cipher == WLAN_CIPHER_SUITE_WEP104)
5197 return;
5198
5199 if (key->flags & IEEE80211_KEY_FLAG_PAIRWISE)
5200 return;
5201
5202 if (cmd != SET_KEY)
5203 return;
5204
5205 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
5206 key->keyidx);
5207 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005208 ath10k_warn(ar, "failed to set vdev %i group key as default key: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02005209 arvif->vdev_id, ret);
Michal Kaziorcfb27d22013-12-02 09:06:36 +01005210}
5211
Kalle Valo5e3dd152013-06-12 20:52:10 +03005212static int ath10k_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd,
5213 struct ieee80211_vif *vif, struct ieee80211_sta *sta,
5214 struct ieee80211_key_conf *key)
5215{
5216 struct ath10k *ar = hw->priv;
5217 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
5218 struct ath10k_peer *peer;
5219 const u8 *peer_addr;
5220 bool is_wep = key->cipher == WLAN_CIPHER_SUITE_WEP40 ||
5221 key->cipher == WLAN_CIPHER_SUITE_WEP104;
5222 int ret = 0;
Michal Kazior29a10002015-04-10 13:05:58 +00005223 int ret2;
Michal Kazior370e5672015-02-18 14:02:26 +01005224 u32 flags = 0;
Michal Kazior29a10002015-04-10 13:05:58 +00005225 u32 flags2;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005226
Bartosz Markowskid7131c02015-03-10 14:32:19 +01005227 /* this one needs to be done in software */
5228 if (key->cipher == WLAN_CIPHER_SUITE_AES_CMAC)
5229 return 1;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005230
David Liuccec9032015-07-24 20:25:32 +03005231 if (arvif->nohwcrypt)
5232 return 1;
5233
Kalle Valo5e3dd152013-06-12 20:52:10 +03005234 if (key->keyidx > WMI_MAX_KEY_INDEX)
5235 return -ENOSPC;
5236
5237 mutex_lock(&ar->conf_mutex);
5238
5239 if (sta)
5240 peer_addr = sta->addr;
5241 else if (arvif->vdev_type == WMI_VDEV_TYPE_STA)
5242 peer_addr = vif->bss_conf.bssid;
5243 else
5244 peer_addr = vif->addr;
5245
5246 key->hw_key_idx = key->keyidx;
5247
Michal Kazior7c8cc7e2015-04-01 22:53:19 +03005248 if (is_wep) {
5249 if (cmd == SET_KEY)
5250 arvif->wep_keys[key->keyidx] = key;
5251 else
5252 arvif->wep_keys[key->keyidx] = NULL;
5253 }
5254
Kalle Valo5e3dd152013-06-12 20:52:10 +03005255 /* the peer should not disappear in mid-way (unless FW goes awry) since
5256 * we already hold conf_mutex. we just make sure its there now. */
5257 spin_lock_bh(&ar->data_lock);
5258 peer = ath10k_peer_find(ar, arvif->vdev_id, peer_addr);
5259 spin_unlock_bh(&ar->data_lock);
5260
5261 if (!peer) {
5262 if (cmd == SET_KEY) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005263 ath10k_warn(ar, "failed to install key for non-existent peer %pM\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03005264 peer_addr);
5265 ret = -EOPNOTSUPP;
5266 goto exit;
5267 } else {
5268 /* if the peer doesn't exist there is no key to disable
5269 * anymore */
5270 goto exit;
5271 }
5272 }
5273
Michal Kazior7cc45732015-03-09 14:24:17 +01005274 if (key->flags & IEEE80211_KEY_FLAG_PAIRWISE)
5275 flags |= WMI_KEY_PAIRWISE;
5276 else
5277 flags |= WMI_KEY_GROUP;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005278
Kalle Valo5e3dd152013-06-12 20:52:10 +03005279 if (is_wep) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03005280 if (cmd == DISABLE_KEY)
5281 ath10k_clear_vdev_key(arvif, key);
Michal Kazior370e5672015-02-18 14:02:26 +01005282
Michal Kaziorad325cb2015-02-18 14:02:27 +01005283 /* When WEP keys are uploaded it's possible that there are
5284 * stations associated already (e.g. when merging) without any
5285 * keys. Static WEP needs an explicit per-peer key upload.
5286 */
5287 if (vif->type == NL80211_IFTYPE_ADHOC &&
5288 cmd == SET_KEY)
5289 ath10k_mac_vif_update_wep_key(arvif, key);
5290
Michal Kazior370e5672015-02-18 14:02:26 +01005291 /* 802.1x never sets the def_wep_key_idx so each set_key()
5292 * call changes default tx key.
5293 *
5294 * Static WEP sets def_wep_key_idx via .set_default_unicast_key
5295 * after first set_key().
5296 */
5297 if (cmd == SET_KEY && arvif->def_wep_key_idx == -1)
5298 flags |= WMI_KEY_TX_USAGE;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005299 }
5300
Michal Kazior370e5672015-02-18 14:02:26 +01005301 ret = ath10k_install_key(arvif, key, cmd, peer_addr, flags);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005302 if (ret) {
David Liuccec9032015-07-24 20:25:32 +03005303 WARN_ON(ret > 0);
Michal Kazior7aa7a722014-08-25 12:09:38 +02005304 ath10k_warn(ar, "failed to install key for vdev %i peer %pM: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02005305 arvif->vdev_id, peer_addr, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005306 goto exit;
5307 }
5308
Michal Kazior29a10002015-04-10 13:05:58 +00005309 /* mac80211 sets static WEP keys as groupwise while firmware requires
5310 * them to be installed twice as both pairwise and groupwise.
5311 */
5312 if (is_wep && !sta && vif->type == NL80211_IFTYPE_STATION) {
5313 flags2 = flags;
5314 flags2 &= ~WMI_KEY_GROUP;
5315 flags2 |= WMI_KEY_PAIRWISE;
5316
5317 ret = ath10k_install_key(arvif, key, cmd, peer_addr, flags2);
5318 if (ret) {
David Liuccec9032015-07-24 20:25:32 +03005319 WARN_ON(ret > 0);
Michal Kazior29a10002015-04-10 13:05:58 +00005320 ath10k_warn(ar, "failed to install (ucast) key for vdev %i peer %pM: %d\n",
5321 arvif->vdev_id, peer_addr, ret);
5322 ret2 = ath10k_install_key(arvif, key, DISABLE_KEY,
5323 peer_addr, flags);
David Liuccec9032015-07-24 20:25:32 +03005324 if (ret2) {
5325 WARN_ON(ret2 > 0);
Michal Kazior29a10002015-04-10 13:05:58 +00005326 ath10k_warn(ar, "failed to disable (mcast) key for vdev %i peer %pM: %d\n",
5327 arvif->vdev_id, peer_addr, ret2);
David Liuccec9032015-07-24 20:25:32 +03005328 }
Michal Kazior29a10002015-04-10 13:05:58 +00005329 goto exit;
5330 }
5331 }
5332
Michal Kaziorcfb27d22013-12-02 09:06:36 +01005333 ath10k_set_key_h_def_keyidx(ar, arvif, cmd, key);
5334
Kalle Valo5e3dd152013-06-12 20:52:10 +03005335 spin_lock_bh(&ar->data_lock);
5336 peer = ath10k_peer_find(ar, arvif->vdev_id, peer_addr);
5337 if (peer && cmd == SET_KEY)
5338 peer->keys[key->keyidx] = key;
5339 else if (peer && cmd == DISABLE_KEY)
5340 peer->keys[key->keyidx] = NULL;
5341 else if (peer == NULL)
5342 /* impossible unless FW goes crazy */
Michal Kazior7aa7a722014-08-25 12:09:38 +02005343 ath10k_warn(ar, "Peer %pM disappeared!\n", peer_addr);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005344 spin_unlock_bh(&ar->data_lock);
5345
5346exit:
5347 mutex_unlock(&ar->conf_mutex);
5348 return ret;
5349}
5350
SenthilKumar Jegadeesan627613f2015-01-29 13:50:38 +02005351static void ath10k_set_default_unicast_key(struct ieee80211_hw *hw,
5352 struct ieee80211_vif *vif,
5353 int keyidx)
5354{
5355 struct ath10k *ar = hw->priv;
5356 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
5357 int ret;
5358
5359 mutex_lock(&arvif->ar->conf_mutex);
5360
5361 if (arvif->ar->state != ATH10K_STATE_ON)
5362 goto unlock;
5363
5364 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %d set keyidx %d\n",
5365 arvif->vdev_id, keyidx);
5366
5367 ret = ath10k_wmi_vdev_set_param(arvif->ar,
5368 arvif->vdev_id,
5369 arvif->ar->wmi.vdev_param->def_keyid,
5370 keyidx);
5371
5372 if (ret) {
5373 ath10k_warn(ar, "failed to update wep key index for vdev %d: %d\n",
5374 arvif->vdev_id,
5375 ret);
5376 goto unlock;
5377 }
5378
5379 arvif->def_wep_key_idx = keyidx;
Michal Kazior370e5672015-02-18 14:02:26 +01005380
SenthilKumar Jegadeesan627613f2015-01-29 13:50:38 +02005381unlock:
5382 mutex_unlock(&arvif->ar->conf_mutex);
5383}
5384
Michal Kazior9797feb2014-02-14 14:49:48 +01005385static void ath10k_sta_rc_update_wk(struct work_struct *wk)
5386{
5387 struct ath10k *ar;
5388 struct ath10k_vif *arvif;
5389 struct ath10k_sta *arsta;
5390 struct ieee80211_sta *sta;
Michal Kazior45c9abc2015-04-21 20:42:58 +03005391 struct cfg80211_chan_def def;
5392 enum ieee80211_band band;
5393 const u8 *ht_mcs_mask;
5394 const u16 *vht_mcs_mask;
Michal Kazior9797feb2014-02-14 14:49:48 +01005395 u32 changed, bw, nss, smps;
5396 int err;
5397
5398 arsta = container_of(wk, struct ath10k_sta, update_wk);
5399 sta = container_of((void *)arsta, struct ieee80211_sta, drv_priv);
5400 arvif = arsta->arvif;
5401 ar = arvif->ar;
5402
Michal Kazior45c9abc2015-04-21 20:42:58 +03005403 if (WARN_ON(ath10k_mac_vif_chan(arvif->vif, &def)))
5404 return;
5405
5406 band = def.chan->band;
5407 ht_mcs_mask = arvif->bitrate_mask.control[band].ht_mcs;
5408 vht_mcs_mask = arvif->bitrate_mask.control[band].vht_mcs;
5409
Michal Kazior9797feb2014-02-14 14:49:48 +01005410 spin_lock_bh(&ar->data_lock);
5411
5412 changed = arsta->changed;
5413 arsta->changed = 0;
5414
5415 bw = arsta->bw;
5416 nss = arsta->nss;
5417 smps = arsta->smps;
5418
5419 spin_unlock_bh(&ar->data_lock);
5420
5421 mutex_lock(&ar->conf_mutex);
5422
Michal Kazior45c9abc2015-04-21 20:42:58 +03005423 nss = max_t(u32, 1, nss);
5424 nss = min(nss, max(ath10k_mac_max_ht_nss(ht_mcs_mask),
5425 ath10k_mac_max_vht_nss(vht_mcs_mask)));
5426
Michal Kazior9797feb2014-02-14 14:49:48 +01005427 if (changed & IEEE80211_RC_BW_CHANGED) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005428 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac update sta %pM peer bw %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01005429 sta->addr, bw);
5430
5431 err = ath10k_wmi_peer_set_param(ar, arvif->vdev_id, sta->addr,
5432 WMI_PEER_CHAN_WIDTH, bw);
5433 if (err)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005434 ath10k_warn(ar, "failed to update STA %pM peer bw %d: %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01005435 sta->addr, bw, err);
5436 }
5437
5438 if (changed & IEEE80211_RC_NSS_CHANGED) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005439 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac update sta %pM nss %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01005440 sta->addr, nss);
5441
5442 err = ath10k_wmi_peer_set_param(ar, arvif->vdev_id, sta->addr,
5443 WMI_PEER_NSS, nss);
5444 if (err)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005445 ath10k_warn(ar, "failed to update STA %pM nss %d: %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01005446 sta->addr, nss, err);
5447 }
5448
5449 if (changed & IEEE80211_RC_SMPS_CHANGED) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005450 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac update sta %pM smps %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01005451 sta->addr, smps);
5452
5453 err = ath10k_wmi_peer_set_param(ar, arvif->vdev_id, sta->addr,
5454 WMI_PEER_SMPS_STATE, smps);
5455 if (err)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005456 ath10k_warn(ar, "failed to update STA %pM smps %d: %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01005457 sta->addr, smps, err);
5458 }
5459
Janusz Dziedzic55884c02014-12-17 12:30:02 +02005460 if (changed & IEEE80211_RC_SUPP_RATES_CHANGED ||
5461 changed & IEEE80211_RC_NSS_CHANGED) {
5462 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac update sta %pM supp rates/nss\n",
Chun-Yeow Yeoh44d6fa92014-03-07 10:19:30 +02005463 sta->addr);
5464
Michal Kazior590922a2014-10-21 10:10:29 +03005465 err = ath10k_station_assoc(ar, arvif->vif, sta, true);
Chun-Yeow Yeoh44d6fa92014-03-07 10:19:30 +02005466 if (err)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005467 ath10k_warn(ar, "failed to reassociate station: %pM\n",
Chun-Yeow Yeoh44d6fa92014-03-07 10:19:30 +02005468 sta->addr);
5469 }
5470
Michal Kazior9797feb2014-02-14 14:49:48 +01005471 mutex_unlock(&ar->conf_mutex);
5472}
5473
Marek Puzyniak7c354242015-03-30 09:51:52 +03005474static int ath10k_mac_inc_num_stations(struct ath10k_vif *arvif,
5475 struct ieee80211_sta *sta)
Michal Kaziorcfd10612014-11-25 15:16:05 +01005476{
5477 struct ath10k *ar = arvif->ar;
5478
5479 lockdep_assert_held(&ar->conf_mutex);
5480
Marek Puzyniak7c354242015-03-30 09:51:52 +03005481 if (arvif->vdev_type == WMI_VDEV_TYPE_STA && !sta->tdls)
Michal Kaziorcfd10612014-11-25 15:16:05 +01005482 return 0;
5483
5484 if (ar->num_stations >= ar->max_num_stations)
5485 return -ENOBUFS;
5486
5487 ar->num_stations++;
5488
5489 return 0;
5490}
5491
Marek Puzyniak7c354242015-03-30 09:51:52 +03005492static void ath10k_mac_dec_num_stations(struct ath10k_vif *arvif,
5493 struct ieee80211_sta *sta)
Michal Kaziorcfd10612014-11-25 15:16:05 +01005494{
5495 struct ath10k *ar = arvif->ar;
5496
5497 lockdep_assert_held(&ar->conf_mutex);
5498
Marek Puzyniak7c354242015-03-30 09:51:52 +03005499 if (arvif->vdev_type == WMI_VDEV_TYPE_STA && !sta->tdls)
Michal Kaziorcfd10612014-11-25 15:16:05 +01005500 return;
5501
5502 ar->num_stations--;
5503}
5504
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005505struct ath10k_mac_tdls_iter_data {
5506 u32 num_tdls_stations;
5507 struct ieee80211_vif *curr_vif;
5508};
5509
5510static void ath10k_mac_tdls_vif_stations_count_iter(void *data,
5511 struct ieee80211_sta *sta)
5512{
5513 struct ath10k_mac_tdls_iter_data *iter_data = data;
5514 struct ath10k_sta *arsta = (struct ath10k_sta *)sta->drv_priv;
5515 struct ieee80211_vif *sta_vif = arsta->arvif->vif;
5516
5517 if (sta->tdls && sta_vif == iter_data->curr_vif)
5518 iter_data->num_tdls_stations++;
5519}
5520
5521static int ath10k_mac_tdls_vif_stations_count(struct ieee80211_hw *hw,
5522 struct ieee80211_vif *vif)
5523{
5524 struct ath10k_mac_tdls_iter_data data = {};
5525
5526 data.curr_vif = vif;
5527
5528 ieee80211_iterate_stations_atomic(hw,
5529 ath10k_mac_tdls_vif_stations_count_iter,
5530 &data);
5531 return data.num_tdls_stations;
5532}
5533
5534static void ath10k_mac_tdls_vifs_count_iter(void *data, u8 *mac,
5535 struct ieee80211_vif *vif)
5536{
5537 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
5538 int *num_tdls_vifs = data;
5539
5540 if (vif->type != NL80211_IFTYPE_STATION)
5541 return;
5542
5543 if (ath10k_mac_tdls_vif_stations_count(arvif->ar->hw, vif) > 0)
5544 (*num_tdls_vifs)++;
5545}
5546
5547static int ath10k_mac_tdls_vifs_count(struct ieee80211_hw *hw)
5548{
5549 int num_tdls_vifs = 0;
5550
5551 ieee80211_iterate_active_interfaces_atomic(hw,
5552 IEEE80211_IFACE_ITER_NORMAL,
5553 ath10k_mac_tdls_vifs_count_iter,
5554 &num_tdls_vifs);
5555 return num_tdls_vifs;
5556}
5557
Kalle Valo5e3dd152013-06-12 20:52:10 +03005558static int ath10k_sta_state(struct ieee80211_hw *hw,
5559 struct ieee80211_vif *vif,
5560 struct ieee80211_sta *sta,
5561 enum ieee80211_sta_state old_state,
5562 enum ieee80211_sta_state new_state)
5563{
5564 struct ath10k *ar = hw->priv;
5565 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kazior9797feb2014-02-14 14:49:48 +01005566 struct ath10k_sta *arsta = (struct ath10k_sta *)sta->drv_priv;
Michal Kaziorbb8f0c62016-03-06 16:14:27 +02005567 struct ath10k_peer *peer;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005568 int ret = 0;
Michal Kazior69427262016-03-06 16:14:30 +02005569 int i;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005570
Michal Kazior76f90022014-02-25 09:29:57 +02005571 if (old_state == IEEE80211_STA_NOTEXIST &&
5572 new_state == IEEE80211_STA_NONE) {
5573 memset(arsta, 0, sizeof(*arsta));
5574 arsta->arvif = arvif;
5575 INIT_WORK(&arsta->update_wk, ath10k_sta_rc_update_wk);
5576 }
5577
Michal Kazior9797feb2014-02-14 14:49:48 +01005578 /* cancel must be done outside the mutex to avoid deadlock */
5579 if ((old_state == IEEE80211_STA_NONE &&
5580 new_state == IEEE80211_STA_NOTEXIST))
5581 cancel_work_sync(&arsta->update_wk);
5582
Kalle Valo5e3dd152013-06-12 20:52:10 +03005583 mutex_lock(&ar->conf_mutex);
5584
5585 if (old_state == IEEE80211_STA_NOTEXIST &&
Michal Kazior077efc82014-10-21 10:10:29 +03005586 new_state == IEEE80211_STA_NONE) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03005587 /*
5588 * New station addition.
5589 */
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005590 enum wmi_peer_type peer_type = WMI_PEER_TYPE_DEFAULT;
5591 u32 num_tdls_stations;
5592 u32 num_tdls_vifs;
5593
Michal Kaziorcfd10612014-11-25 15:16:05 +01005594 ath10k_dbg(ar, ATH10K_DBG_MAC,
5595 "mac vdev %d peer create %pM (new sta) sta %d / %d peer %d / %d\n",
5596 arvif->vdev_id, sta->addr,
5597 ar->num_stations + 1, ar->max_num_stations,
5598 ar->num_peers + 1, ar->max_num_peers);
Bartosz Markowski0e759f32014-01-02 14:38:33 +01005599
Marek Puzyniak7c354242015-03-30 09:51:52 +03005600 ret = ath10k_mac_inc_num_stations(arvif, sta);
Michal Kaziorcfd10612014-11-25 15:16:05 +01005601 if (ret) {
5602 ath10k_warn(ar, "refusing to associate station: too many connected already (%d)\n",
5603 ar->max_num_stations);
Bartosz Markowski0e759f32014-01-02 14:38:33 +01005604 goto exit;
5605 }
5606
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005607 if (sta->tdls)
5608 peer_type = WMI_PEER_TYPE_TDLS;
5609
Michal Kazior69427262016-03-06 16:14:30 +02005610 ret = ath10k_peer_create(ar, vif, sta, arvif->vdev_id,
5611 sta->addr, peer_type);
Michal Kaziora52c0282014-11-25 15:16:03 +01005612 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005613 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 -08005614 sta->addr, arvif->vdev_id, ret);
Marek Puzyniak7c354242015-03-30 09:51:52 +03005615 ath10k_mac_dec_num_stations(arvif, sta);
Michal Kaziora52c0282014-11-25 15:16:03 +01005616 goto exit;
5617 }
Michal Kazior077efc82014-10-21 10:10:29 +03005618
Michal Kaziorbb8f0c62016-03-06 16:14:27 +02005619 spin_lock_bh(&ar->data_lock);
5620
5621 peer = ath10k_peer_find(ar, arvif->vdev_id, sta->addr);
5622 if (!peer) {
5623 ath10k_warn(ar, "failed to lookup peer %pM on vdev %i\n",
5624 vif->addr, arvif->vdev_id);
5625 spin_unlock_bh(&ar->data_lock);
5626 ath10k_peer_delete(ar, arvif->vdev_id, sta->addr);
5627 ath10k_mac_dec_num_stations(arvif, sta);
5628 ret = -ENOENT;
5629 goto exit;
5630 }
5631
5632 arsta->peer_id = find_first_bit(peer->peer_ids,
5633 ATH10K_MAX_NUM_PEER_IDS);
5634
5635 spin_unlock_bh(&ar->data_lock);
5636
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005637 if (!sta->tdls)
5638 goto exit;
Michal Kazior077efc82014-10-21 10:10:29 +03005639
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005640 num_tdls_stations = ath10k_mac_tdls_vif_stations_count(hw, vif);
5641 num_tdls_vifs = ath10k_mac_tdls_vifs_count(hw);
5642
5643 if (num_tdls_vifs >= ar->max_num_tdls_vdevs &&
5644 num_tdls_stations == 0) {
5645 ath10k_warn(ar, "vdev %i exceeded maximum number of tdls vdevs %i\n",
5646 arvif->vdev_id, ar->max_num_tdls_vdevs);
5647 ath10k_peer_delete(ar, arvif->vdev_id, sta->addr);
5648 ath10k_mac_dec_num_stations(arvif, sta);
5649 ret = -ENOBUFS;
5650 goto exit;
5651 }
5652
5653 if (num_tdls_stations == 0) {
5654 /* This is the first tdls peer in current vif */
5655 enum wmi_tdls_state state = WMI_TDLS_ENABLE_ACTIVE;
5656
5657 ret = ath10k_wmi_update_fw_tdls_state(ar, arvif->vdev_id,
5658 state);
Michal Kazior077efc82014-10-21 10:10:29 +03005659 if (ret) {
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005660 ath10k_warn(ar, "failed to update fw tdls state on vdev %i: %i\n",
Michal Kazior077efc82014-10-21 10:10:29 +03005661 arvif->vdev_id, ret);
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005662 ath10k_peer_delete(ar, arvif->vdev_id,
5663 sta->addr);
5664 ath10k_mac_dec_num_stations(arvif, sta);
Michal Kazior077efc82014-10-21 10:10:29 +03005665 goto exit;
5666 }
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005667 }
Michal Kazior077efc82014-10-21 10:10:29 +03005668
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005669 ret = ath10k_mac_tdls_peer_update(ar, arvif->vdev_id, sta,
5670 WMI_TDLS_PEER_STATE_PEERING);
5671 if (ret) {
5672 ath10k_warn(ar,
5673 "failed to update tdls peer %pM for vdev %d when adding a new sta: %i\n",
5674 sta->addr, arvif->vdev_id, ret);
5675 ath10k_peer_delete(ar, arvif->vdev_id, sta->addr);
5676 ath10k_mac_dec_num_stations(arvif, sta);
5677
5678 if (num_tdls_stations != 0)
5679 goto exit;
5680 ath10k_wmi_update_fw_tdls_state(ar, arvif->vdev_id,
5681 WMI_TDLS_DISABLE);
Michal Kazior077efc82014-10-21 10:10:29 +03005682 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03005683 } else if ((old_state == IEEE80211_STA_NONE &&
5684 new_state == IEEE80211_STA_NOTEXIST)) {
5685 /*
5686 * Existing station deletion.
5687 */
Michal Kazior7aa7a722014-08-25 12:09:38 +02005688 ath10k_dbg(ar, ATH10K_DBG_MAC,
Kalle Valo60c3daa2013-09-08 17:56:07 +03005689 "mac vdev %d peer delete %pM (sta gone)\n",
5690 arvif->vdev_id, sta->addr);
Michal Kazior077efc82014-10-21 10:10:29 +03005691
Kalle Valo5e3dd152013-06-12 20:52:10 +03005692 ret = ath10k_peer_delete(ar, arvif->vdev_id, sta->addr);
5693 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005694 ath10k_warn(ar, "failed to delete peer %pM for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02005695 sta->addr, arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005696
Marek Puzyniak7c354242015-03-30 09:51:52 +03005697 ath10k_mac_dec_num_stations(arvif, sta);
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005698
Michal Kazior69427262016-03-06 16:14:30 +02005699 spin_lock_bh(&ar->data_lock);
5700 for (i = 0; i < ARRAY_SIZE(ar->peer_map); i++) {
5701 peer = ar->peer_map[i];
5702 if (!peer)
5703 continue;
5704
5705 if (peer->sta == sta) {
5706 ath10k_warn(ar, "found sta peer %pM entry on vdev %i after it was supposedly removed\n",
5707 sta->addr, arvif->vdev_id);
5708 peer->sta = NULL;
5709 }
5710 }
5711 spin_unlock_bh(&ar->data_lock);
5712
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005713 if (!sta->tdls)
5714 goto exit;
5715
5716 if (ath10k_mac_tdls_vif_stations_count(hw, vif))
5717 goto exit;
5718
5719 /* This was the last tdls peer in current vif */
5720 ret = ath10k_wmi_update_fw_tdls_state(ar, arvif->vdev_id,
5721 WMI_TDLS_DISABLE);
5722 if (ret) {
5723 ath10k_warn(ar, "failed to update fw tdls state on vdev %i: %i\n",
5724 arvif->vdev_id, ret);
5725 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03005726 } else if (old_state == IEEE80211_STA_AUTH &&
5727 new_state == IEEE80211_STA_ASSOC &&
5728 (vif->type == NL80211_IFTYPE_AP ||
Bob Copelandb6c7baf2015-09-09 12:47:36 -04005729 vif->type == NL80211_IFTYPE_MESH_POINT ||
Kalle Valo5e3dd152013-06-12 20:52:10 +03005730 vif->type == NL80211_IFTYPE_ADHOC)) {
5731 /*
5732 * New association.
5733 */
Michal Kazior7aa7a722014-08-25 12:09:38 +02005734 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac sta %pM associated\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03005735 sta->addr);
5736
Michal Kazior590922a2014-10-21 10:10:29 +03005737 ret = ath10k_station_assoc(ar, vif, sta, false);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005738 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005739 ath10k_warn(ar, "failed to associate station %pM for vdev %i: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02005740 sta->addr, arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005741 } else if (old_state == IEEE80211_STA_ASSOC &&
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005742 new_state == IEEE80211_STA_AUTHORIZED &&
5743 sta->tdls) {
5744 /*
5745 * Tdls station authorized.
5746 */
5747 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac tdls sta %pM authorized\n",
5748 sta->addr);
5749
5750 ret = ath10k_station_assoc(ar, vif, sta, false);
5751 if (ret) {
5752 ath10k_warn(ar, "failed to associate tdls station %pM for vdev %i: %i\n",
5753 sta->addr, arvif->vdev_id, ret);
5754 goto exit;
5755 }
5756
5757 ret = ath10k_mac_tdls_peer_update(ar, arvif->vdev_id, sta,
5758 WMI_TDLS_PEER_STATE_CONNECTED);
5759 if (ret)
5760 ath10k_warn(ar, "failed to update tdls peer %pM for vdev %i: %i\n",
5761 sta->addr, arvif->vdev_id, ret);
5762 } else if (old_state == IEEE80211_STA_ASSOC &&
5763 new_state == IEEE80211_STA_AUTH &&
5764 (vif->type == NL80211_IFTYPE_AP ||
Bob Copelandb6c7baf2015-09-09 12:47:36 -04005765 vif->type == NL80211_IFTYPE_MESH_POINT ||
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005766 vif->type == NL80211_IFTYPE_ADHOC)) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03005767 /*
5768 * Disassociation.
5769 */
Michal Kazior7aa7a722014-08-25 12:09:38 +02005770 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac sta %pM disassociated\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03005771 sta->addr);
5772
Michal Kazior590922a2014-10-21 10:10:29 +03005773 ret = ath10k_station_disassoc(ar, vif, sta);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005774 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005775 ath10k_warn(ar, "failed to disassociate station: %pM vdev %i: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02005776 sta->addr, arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005777 }
Bartosz Markowski0e759f32014-01-02 14:38:33 +01005778exit:
Kalle Valo5e3dd152013-06-12 20:52:10 +03005779 mutex_unlock(&ar->conf_mutex);
5780 return ret;
5781}
5782
5783static int ath10k_conf_tx_uapsd(struct ath10k *ar, struct ieee80211_vif *vif,
Kalle Valo5b07e072014-09-14 12:50:06 +03005784 u16 ac, bool enable)
Kalle Valo5e3dd152013-06-12 20:52:10 +03005785{
5786 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kaziorb0e56152015-01-24 12:14:52 +02005787 struct wmi_sta_uapsd_auto_trig_arg arg = {};
5788 u32 prio = 0, acc = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005789 u32 value = 0;
5790 int ret = 0;
5791
Michal Kazior548db542013-07-05 16:15:15 +03005792 lockdep_assert_held(&ar->conf_mutex);
5793
Kalle Valo5e3dd152013-06-12 20:52:10 +03005794 if (arvif->vdev_type != WMI_VDEV_TYPE_STA)
5795 return 0;
5796
5797 switch (ac) {
5798 case IEEE80211_AC_VO:
5799 value = WMI_STA_PS_UAPSD_AC3_DELIVERY_EN |
5800 WMI_STA_PS_UAPSD_AC3_TRIGGER_EN;
Michal Kaziorb0e56152015-01-24 12:14:52 +02005801 prio = 7;
5802 acc = 3;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005803 break;
5804 case IEEE80211_AC_VI:
5805 value = WMI_STA_PS_UAPSD_AC2_DELIVERY_EN |
5806 WMI_STA_PS_UAPSD_AC2_TRIGGER_EN;
Michal Kaziorb0e56152015-01-24 12:14:52 +02005807 prio = 5;
5808 acc = 2;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005809 break;
5810 case IEEE80211_AC_BE:
5811 value = WMI_STA_PS_UAPSD_AC1_DELIVERY_EN |
5812 WMI_STA_PS_UAPSD_AC1_TRIGGER_EN;
Michal Kaziorb0e56152015-01-24 12:14:52 +02005813 prio = 2;
5814 acc = 1;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005815 break;
5816 case IEEE80211_AC_BK:
5817 value = WMI_STA_PS_UAPSD_AC0_DELIVERY_EN |
5818 WMI_STA_PS_UAPSD_AC0_TRIGGER_EN;
Michal Kaziorb0e56152015-01-24 12:14:52 +02005819 prio = 0;
5820 acc = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005821 break;
5822 }
5823
5824 if (enable)
5825 arvif->u.sta.uapsd |= value;
5826 else
5827 arvif->u.sta.uapsd &= ~value;
5828
5829 ret = ath10k_wmi_set_sta_ps_param(ar, arvif->vdev_id,
5830 WMI_STA_PS_PARAM_UAPSD,
5831 arvif->u.sta.uapsd);
5832 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005833 ath10k_warn(ar, "failed to set uapsd params: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005834 goto exit;
5835 }
5836
5837 if (arvif->u.sta.uapsd)
5838 value = WMI_STA_PS_RX_WAKE_POLICY_POLL_UAPSD;
5839 else
5840 value = WMI_STA_PS_RX_WAKE_POLICY_WAKE;
5841
5842 ret = ath10k_wmi_set_sta_ps_param(ar, arvif->vdev_id,
5843 WMI_STA_PS_PARAM_RX_WAKE_POLICY,
5844 value);
5845 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005846 ath10k_warn(ar, "failed to set rx wake param: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005847
Michal Kazior9f9b5742014-12-12 12:41:36 +01005848 ret = ath10k_mac_vif_recalc_ps_wake_threshold(arvif);
5849 if (ret) {
5850 ath10k_warn(ar, "failed to recalc ps wake threshold on vdev %i: %d\n",
5851 arvif->vdev_id, ret);
5852 return ret;
5853 }
5854
5855 ret = ath10k_mac_vif_recalc_ps_poll_count(arvif);
5856 if (ret) {
5857 ath10k_warn(ar, "failed to recalc ps poll count on vdev %i: %d\n",
5858 arvif->vdev_id, ret);
5859 return ret;
5860 }
5861
Michal Kaziorb0e56152015-01-24 12:14:52 +02005862 if (test_bit(WMI_SERVICE_STA_UAPSD_BASIC_AUTO_TRIG, ar->wmi.svc_map) ||
5863 test_bit(WMI_SERVICE_STA_UAPSD_VAR_AUTO_TRIG, ar->wmi.svc_map)) {
5864 /* Only userspace can make an educated decision when to send
5865 * trigger frame. The following effectively disables u-UAPSD
5866 * autotrigger in firmware (which is enabled by default
5867 * provided the autotrigger service is available).
5868 */
5869
5870 arg.wmm_ac = acc;
5871 arg.user_priority = prio;
5872 arg.service_interval = 0;
5873 arg.suspend_interval = WMI_STA_UAPSD_MAX_INTERVAL_MSEC;
5874 arg.delay_interval = WMI_STA_UAPSD_MAX_INTERVAL_MSEC;
5875
5876 ret = ath10k_wmi_vdev_sta_uapsd(ar, arvif->vdev_id,
5877 arvif->bssid, &arg, 1);
5878 if (ret) {
5879 ath10k_warn(ar, "failed to set uapsd auto trigger %d\n",
5880 ret);
5881 return ret;
5882 }
5883 }
5884
Kalle Valo5e3dd152013-06-12 20:52:10 +03005885exit:
5886 return ret;
5887}
5888
5889static int ath10k_conf_tx(struct ieee80211_hw *hw,
5890 struct ieee80211_vif *vif, u16 ac,
5891 const struct ieee80211_tx_queue_params *params)
5892{
5893 struct ath10k *ar = hw->priv;
Michal Kazior5e752e42015-01-19 09:53:41 +01005894 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005895 struct wmi_wmm_params_arg *p = NULL;
5896 int ret;
5897
5898 mutex_lock(&ar->conf_mutex);
5899
5900 switch (ac) {
5901 case IEEE80211_AC_VO:
Michal Kazior5e752e42015-01-19 09:53:41 +01005902 p = &arvif->wmm_params.ac_vo;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005903 break;
5904 case IEEE80211_AC_VI:
Michal Kazior5e752e42015-01-19 09:53:41 +01005905 p = &arvif->wmm_params.ac_vi;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005906 break;
5907 case IEEE80211_AC_BE:
Michal Kazior5e752e42015-01-19 09:53:41 +01005908 p = &arvif->wmm_params.ac_be;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005909 break;
5910 case IEEE80211_AC_BK:
Michal Kazior5e752e42015-01-19 09:53:41 +01005911 p = &arvif->wmm_params.ac_bk;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005912 break;
5913 }
5914
5915 if (WARN_ON(!p)) {
5916 ret = -EINVAL;
5917 goto exit;
5918 }
5919
5920 p->cwmin = params->cw_min;
5921 p->cwmax = params->cw_max;
5922 p->aifs = params->aifs;
5923
5924 /*
5925 * The channel time duration programmed in the HW is in absolute
5926 * microseconds, while mac80211 gives the txop in units of
5927 * 32 microseconds.
5928 */
5929 p->txop = params->txop * 32;
5930
Michal Kazior7fc979a2015-01-28 09:57:28 +02005931 if (ar->wmi.ops->gen_vdev_wmm_conf) {
5932 ret = ath10k_wmi_vdev_wmm_conf(ar, arvif->vdev_id,
5933 &arvif->wmm_params);
5934 if (ret) {
5935 ath10k_warn(ar, "failed to set vdev wmm params on vdev %i: %d\n",
5936 arvif->vdev_id, ret);
5937 goto exit;
5938 }
5939 } else {
5940 /* This won't work well with multi-interface cases but it's
5941 * better than nothing.
5942 */
5943 ret = ath10k_wmi_pdev_set_wmm_params(ar, &arvif->wmm_params);
5944 if (ret) {
5945 ath10k_warn(ar, "failed to set wmm params: %d\n", ret);
5946 goto exit;
5947 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03005948 }
5949
5950 ret = ath10k_conf_tx_uapsd(ar, vif, ac, params->uapsd);
5951 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005952 ath10k_warn(ar, "failed to set sta uapsd: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005953
5954exit:
5955 mutex_unlock(&ar->conf_mutex);
5956 return ret;
5957}
5958
5959#define ATH10K_ROC_TIMEOUT_HZ (2*HZ)
5960
5961static int ath10k_remain_on_channel(struct ieee80211_hw *hw,
5962 struct ieee80211_vif *vif,
5963 struct ieee80211_channel *chan,
5964 int duration,
5965 enum ieee80211_roc_type type)
5966{
5967 struct ath10k *ar = hw->priv;
5968 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
5969 struct wmi_start_scan_arg arg;
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005970 int ret = 0;
Michal Kaziorfcf98442015-03-31 11:03:47 +00005971 u32 scan_time_msec;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005972
5973 mutex_lock(&ar->conf_mutex);
5974
5975 spin_lock_bh(&ar->data_lock);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005976 switch (ar->scan.state) {
5977 case ATH10K_SCAN_IDLE:
5978 reinit_completion(&ar->scan.started);
5979 reinit_completion(&ar->scan.completed);
5980 reinit_completion(&ar->scan.on_channel);
5981 ar->scan.state = ATH10K_SCAN_STARTING;
5982 ar->scan.is_roc = true;
5983 ar->scan.vdev_id = arvif->vdev_id;
5984 ar->scan.roc_freq = chan->center_freq;
Michal Kaziord710e752015-07-09 13:08:36 +02005985 ar->scan.roc_notify = true;
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005986 ret = 0;
5987 break;
5988 case ATH10K_SCAN_STARTING:
5989 case ATH10K_SCAN_RUNNING:
5990 case ATH10K_SCAN_ABORTING:
Kalle Valo5e3dd152013-06-12 20:52:10 +03005991 ret = -EBUSY;
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005992 break;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005993 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03005994 spin_unlock_bh(&ar->data_lock);
5995
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005996 if (ret)
5997 goto exit;
5998
Michal Kaziorfcf98442015-03-31 11:03:47 +00005999 scan_time_msec = ar->hw->wiphy->max_remain_on_channel_duration * 2;
Michal Kaziordcca0bd2014-11-24 14:58:32 +01006000
Kalle Valo5e3dd152013-06-12 20:52:10 +03006001 memset(&arg, 0, sizeof(arg));
6002 ath10k_wmi_start_scan_init(ar, &arg);
6003 arg.vdev_id = arvif->vdev_id;
6004 arg.scan_id = ATH10K_SCAN_ID;
6005 arg.n_channels = 1;
6006 arg.channels[0] = chan->center_freq;
Michal Kaziorfcf98442015-03-31 11:03:47 +00006007 arg.dwell_time_active = scan_time_msec;
6008 arg.dwell_time_passive = scan_time_msec;
6009 arg.max_scan_time = scan_time_msec;
Kalle Valo5e3dd152013-06-12 20:52:10 +03006010 arg.scan_ctrl_flags |= WMI_SCAN_FLAG_PASSIVE;
6011 arg.scan_ctrl_flags |= WMI_SCAN_FILTER_PROBE_REQ;
Michal Kaziordbd3f9f2015-03-31 11:03:48 +00006012 arg.burst_duration_ms = duration;
Kalle Valo5e3dd152013-06-12 20:52:10 +03006013
6014 ret = ath10k_start_scan(ar, &arg);
6015 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02006016 ath10k_warn(ar, "failed to start roc scan: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03006017 spin_lock_bh(&ar->data_lock);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02006018 ar->scan.state = ATH10K_SCAN_IDLE;
Kalle Valo5e3dd152013-06-12 20:52:10 +03006019 spin_unlock_bh(&ar->data_lock);
6020 goto exit;
6021 }
6022
6023 ret = wait_for_completion_timeout(&ar->scan.on_channel, 3*HZ);
6024 if (ret == 0) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02006025 ath10k_warn(ar, "failed to switch to channel for roc scan\n");
Michal Kazior5c81c7f2014-08-05 14:54:44 +02006026
6027 ret = ath10k_scan_stop(ar);
6028 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02006029 ath10k_warn(ar, "failed to stop scan: %d\n", ret);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02006030
Kalle Valo5e3dd152013-06-12 20:52:10 +03006031 ret = -ETIMEDOUT;
6032 goto exit;
6033 }
6034
Michal Kaziorfcf98442015-03-31 11:03:47 +00006035 ieee80211_queue_delayed_work(ar->hw, &ar->scan.timeout,
6036 msecs_to_jiffies(duration));
6037
Kalle Valo5e3dd152013-06-12 20:52:10 +03006038 ret = 0;
6039exit:
6040 mutex_unlock(&ar->conf_mutex);
6041 return ret;
6042}
6043
6044static int ath10k_cancel_remain_on_channel(struct ieee80211_hw *hw)
6045{
6046 struct ath10k *ar = hw->priv;
6047
6048 mutex_lock(&ar->conf_mutex);
Michal Kaziord710e752015-07-09 13:08:36 +02006049
6050 spin_lock_bh(&ar->data_lock);
6051 ar->scan.roc_notify = false;
6052 spin_unlock_bh(&ar->data_lock);
6053
Michal Kazior5c81c7f2014-08-05 14:54:44 +02006054 ath10k_scan_abort(ar);
Michal Kaziord710e752015-07-09 13:08:36 +02006055
Kalle Valo5e3dd152013-06-12 20:52:10 +03006056 mutex_unlock(&ar->conf_mutex);
6057
Michal Kazior4eb2e162014-10-28 10:23:09 +01006058 cancel_delayed_work_sync(&ar->scan.timeout);
6059
Kalle Valo5e3dd152013-06-12 20:52:10 +03006060 return 0;
6061}
6062
6063/*
6064 * Both RTS and Fragmentation threshold are interface-specific
6065 * in ath10k, but device-specific in mac80211.
6066 */
Kalle Valo5e3dd152013-06-12 20:52:10 +03006067
6068static int ath10k_set_rts_threshold(struct ieee80211_hw *hw, u32 value)
6069{
Kalle Valo5e3dd152013-06-12 20:52:10 +03006070 struct ath10k *ar = hw->priv;
Michal Kaziorad088bf2013-10-16 15:44:46 +03006071 struct ath10k_vif *arvif;
6072 int ret = 0;
Michal Kazior548db542013-07-05 16:15:15 +03006073
Michal Kaziorad088bf2013-10-16 15:44:46 +03006074 mutex_lock(&ar->conf_mutex);
6075 list_for_each_entry(arvif, &ar->arvifs, list) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02006076 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %d rts threshold %d\n",
Michal Kaziorad088bf2013-10-16 15:44:46 +03006077 arvif->vdev_id, value);
Kalle Valo60c3daa2013-09-08 17:56:07 +03006078
Michal Kaziorad088bf2013-10-16 15:44:46 +03006079 ret = ath10k_mac_set_rts(arvif, value);
6080 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02006081 ath10k_warn(ar, "failed to set rts threshold for vdev %d: %d\n",
Michal Kaziorad088bf2013-10-16 15:44:46 +03006082 arvif->vdev_id, ret);
6083 break;
6084 }
6085 }
6086 mutex_unlock(&ar->conf_mutex);
6087
6088 return ret;
Kalle Valo5e3dd152013-06-12 20:52:10 +03006089}
6090
Michal Kazior92092fe2015-08-03 11:16:43 +02006091static int ath10k_mac_op_set_frag_threshold(struct ieee80211_hw *hw, u32 value)
6092{
6093 /* Even though there's a WMI enum for fragmentation threshold no known
6094 * firmware actually implements it. Moreover it is not possible to rely
6095 * frame fragmentation to mac80211 because firmware clears the "more
6096 * fragments" bit in frame control making it impossible for remote
6097 * devices to reassemble frames.
6098 *
6099 * Hence implement a dummy callback just to say fragmentation isn't
6100 * supported. This effectively prevents mac80211 from doing frame
6101 * fragmentation in software.
6102 */
6103 return -EOPNOTSUPP;
6104}
6105
Emmanuel Grumbach77be2c52014-03-27 11:30:29 +02006106static void ath10k_flush(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
6107 u32 queues, bool drop)
Kalle Valo5e3dd152013-06-12 20:52:10 +03006108{
6109 struct ath10k *ar = hw->priv;
Michal Kazioraffd3212013-07-16 09:54:35 +02006110 bool skip;
Nicholas Mc Guired4298a32015-06-15 14:46:43 +03006111 long time_left;
Kalle Valo5e3dd152013-06-12 20:52:10 +03006112
6113 /* mac80211 doesn't care if we really xmit queued frames or not
6114 * we'll collect those frames either way if we stop/delete vdevs */
6115 if (drop)
6116 return;
6117
Michal Kazior548db542013-07-05 16:15:15 +03006118 mutex_lock(&ar->conf_mutex);
6119
Michal Kazioraffd3212013-07-16 09:54:35 +02006120 if (ar->state == ATH10K_STATE_WEDGED)
6121 goto skip;
6122
Nicholas Mc Guired4298a32015-06-15 14:46:43 +03006123 time_left = wait_event_timeout(ar->htt.empty_tx_wq, ({
Kalle Valo5e3dd152013-06-12 20:52:10 +03006124 bool empty;
Michal Kazioraffd3212013-07-16 09:54:35 +02006125
Michal Kazioredb82362013-07-05 16:15:14 +03006126 spin_lock_bh(&ar->htt.tx_lock);
Michal Kazior0945baf2013-09-18 14:43:18 +02006127 empty = (ar->htt.num_pending_tx == 0);
Michal Kazioredb82362013-07-05 16:15:14 +03006128 spin_unlock_bh(&ar->htt.tx_lock);
Michal Kazioraffd3212013-07-16 09:54:35 +02006129
Michal Kazior7962b0d2014-10-28 10:34:38 +01006130 skip = (ar->state == ATH10K_STATE_WEDGED) ||
6131 test_bit(ATH10K_FLAG_CRASH_FLUSH,
6132 &ar->dev_flags);
Michal Kazioraffd3212013-07-16 09:54:35 +02006133
6134 (empty || skip);
Kalle Valo5e3dd152013-06-12 20:52:10 +03006135 }), ATH10K_FLUSH_TIMEOUT_HZ);
Michal Kazioraffd3212013-07-16 09:54:35 +02006136
Nicholas Mc Guired4298a32015-06-15 14:46:43 +03006137 if (time_left == 0 || skip)
6138 ath10k_warn(ar, "failed to flush transmit queue (skip %i ar-state %i): %ld\n",
6139 skip, ar->state, time_left);
Michal Kazior548db542013-07-05 16:15:15 +03006140
Michal Kazioraffd3212013-07-16 09:54:35 +02006141skip:
Michal Kazior548db542013-07-05 16:15:15 +03006142 mutex_unlock(&ar->conf_mutex);
Kalle Valo5e3dd152013-06-12 20:52:10 +03006143}
6144
6145/* TODO: Implement this function properly
6146 * For now it is needed to reply to Probe Requests in IBSS mode.
6147 * Propably we need this information from FW.
6148 */
6149static int ath10k_tx_last_beacon(struct ieee80211_hw *hw)
6150{
6151 return 1;
6152}
6153
Eliad Pellercf2c92d2014-11-04 11:43:54 +02006154static void ath10k_reconfig_complete(struct ieee80211_hw *hw,
6155 enum ieee80211_reconfig_type reconfig_type)
Michal Kazioraffd3212013-07-16 09:54:35 +02006156{
6157 struct ath10k *ar = hw->priv;
6158
Eliad Pellercf2c92d2014-11-04 11:43:54 +02006159 if (reconfig_type != IEEE80211_RECONFIG_TYPE_RESTART)
6160 return;
6161
Michal Kazioraffd3212013-07-16 09:54:35 +02006162 mutex_lock(&ar->conf_mutex);
6163
6164 /* If device failed to restart it will be in a different state, e.g.
6165 * ATH10K_STATE_WEDGED */
6166 if (ar->state == ATH10K_STATE_RESTARTED) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02006167 ath10k_info(ar, "device successfully recovered\n");
Michal Kazioraffd3212013-07-16 09:54:35 +02006168 ar->state = ATH10K_STATE_ON;
Michal Kazior7962b0d2014-10-28 10:34:38 +01006169 ieee80211_wake_queues(ar->hw);
Michal Kazioraffd3212013-07-16 09:54:35 +02006170 }
6171
6172 mutex_unlock(&ar->conf_mutex);
6173}
6174
Michal Kazior2e1dea42013-07-31 10:32:40 +02006175static int ath10k_get_survey(struct ieee80211_hw *hw, int idx,
6176 struct survey_info *survey)
6177{
6178 struct ath10k *ar = hw->priv;
6179 struct ieee80211_supported_band *sband;
6180 struct survey_info *ar_survey = &ar->survey[idx];
6181 int ret = 0;
6182
6183 mutex_lock(&ar->conf_mutex);
6184
6185 sband = hw->wiphy->bands[IEEE80211_BAND_2GHZ];
6186 if (sband && idx >= sband->n_channels) {
6187 idx -= sband->n_channels;
6188 sband = NULL;
6189 }
6190
6191 if (!sband)
6192 sband = hw->wiphy->bands[IEEE80211_BAND_5GHZ];
6193
6194 if (!sband || idx >= sband->n_channels) {
6195 ret = -ENOENT;
6196 goto exit;
6197 }
6198
6199 spin_lock_bh(&ar->data_lock);
6200 memcpy(survey, ar_survey, sizeof(*survey));
6201 spin_unlock_bh(&ar->data_lock);
6202
6203 survey->channel = &sband->channels[idx];
6204
Felix Fietkaufa1d4df2014-10-23 17:04:28 +03006205 if (ar->rx_channel == survey->channel)
6206 survey->filled |= SURVEY_INFO_IN_USE;
6207
Michal Kazior2e1dea42013-07-31 10:32:40 +02006208exit:
6209 mutex_unlock(&ar->conf_mutex);
6210 return ret;
6211}
6212
Michal Kazior3ae54222015-03-31 10:49:20 +00006213static bool
6214ath10k_mac_bitrate_mask_has_single_rate(struct ath10k *ar,
6215 enum ieee80211_band band,
6216 const struct cfg80211_bitrate_mask *mask)
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006217{
Michal Kazior3ae54222015-03-31 10:49:20 +00006218 int num_rates = 0;
6219 int i;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006220
Michal Kazior3ae54222015-03-31 10:49:20 +00006221 num_rates += hweight32(mask->control[band].legacy);
6222
6223 for (i = 0; i < ARRAY_SIZE(mask->control[band].ht_mcs); i++)
6224 num_rates += hweight8(mask->control[band].ht_mcs[i]);
6225
6226 for (i = 0; i < ARRAY_SIZE(mask->control[band].vht_mcs); i++)
6227 num_rates += hweight16(mask->control[band].vht_mcs[i]);
6228
6229 return num_rates == 1;
6230}
6231
6232static bool
6233ath10k_mac_bitrate_mask_get_single_nss(struct ath10k *ar,
6234 enum ieee80211_band band,
6235 const struct cfg80211_bitrate_mask *mask,
6236 int *nss)
6237{
6238 struct ieee80211_supported_band *sband = &ar->mac.sbands[band];
6239 u16 vht_mcs_map = le16_to_cpu(sband->vht_cap.vht_mcs.tx_mcs_map);
6240 u8 ht_nss_mask = 0;
6241 u8 vht_nss_mask = 0;
6242 int i;
6243
6244 if (mask->control[band].legacy)
6245 return false;
6246
6247 for (i = 0; i < ARRAY_SIZE(mask->control[band].ht_mcs); i++) {
6248 if (mask->control[band].ht_mcs[i] == 0)
6249 continue;
6250 else if (mask->control[band].ht_mcs[i] ==
6251 sband->ht_cap.mcs.rx_mask[i])
6252 ht_nss_mask |= BIT(i);
6253 else
6254 return false;
6255 }
6256
6257 for (i = 0; i < ARRAY_SIZE(mask->control[band].vht_mcs); i++) {
6258 if (mask->control[band].vht_mcs[i] == 0)
6259 continue;
6260 else if (mask->control[band].vht_mcs[i] ==
6261 ath10k_mac_get_max_vht_mcs_map(vht_mcs_map, i))
6262 vht_nss_mask |= BIT(i);
6263 else
6264 return false;
6265 }
6266
6267 if (ht_nss_mask != vht_nss_mask)
6268 return false;
6269
6270 if (ht_nss_mask == 0)
6271 return false;
6272
6273 if (BIT(fls(ht_nss_mask)) - 1 != ht_nss_mask)
6274 return false;
6275
6276 *nss = fls(ht_nss_mask);
6277
6278 return true;
6279}
6280
6281static int
6282ath10k_mac_bitrate_mask_get_single_rate(struct ath10k *ar,
6283 enum ieee80211_band band,
6284 const struct cfg80211_bitrate_mask *mask,
6285 u8 *rate, u8 *nss)
6286{
6287 struct ieee80211_supported_band *sband = &ar->mac.sbands[band];
6288 int rate_idx;
6289 int i;
6290 u16 bitrate;
6291 u8 preamble;
6292 u8 hw_rate;
6293
6294 if (hweight32(mask->control[band].legacy) == 1) {
6295 rate_idx = ffs(mask->control[band].legacy) - 1;
6296
6297 hw_rate = sband->bitrates[rate_idx].hw_value;
6298 bitrate = sband->bitrates[rate_idx].bitrate;
6299
6300 if (ath10k_mac_bitrate_is_cck(bitrate))
6301 preamble = WMI_RATE_PREAMBLE_CCK;
6302 else
6303 preamble = WMI_RATE_PREAMBLE_OFDM;
6304
6305 *nss = 1;
6306 *rate = preamble << 6 |
6307 (*nss - 1) << 4 |
6308 hw_rate << 0;
6309
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006310 return 0;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006311 }
6312
Michal Kazior3ae54222015-03-31 10:49:20 +00006313 for (i = 0; i < ARRAY_SIZE(mask->control[band].ht_mcs); i++) {
6314 if (hweight8(mask->control[band].ht_mcs[i]) == 1) {
6315 *nss = i + 1;
6316 *rate = WMI_RATE_PREAMBLE_HT << 6 |
6317 (*nss - 1) << 4 |
6318 (ffs(mask->control[band].ht_mcs[i]) - 1);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006319
Michal Kazior3ae54222015-03-31 10:49:20 +00006320 return 0;
6321 }
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006322 }
6323
Michal Kazior3ae54222015-03-31 10:49:20 +00006324 for (i = 0; i < ARRAY_SIZE(mask->control[band].vht_mcs); i++) {
6325 if (hweight16(mask->control[band].vht_mcs[i]) == 1) {
6326 *nss = i + 1;
6327 *rate = WMI_RATE_PREAMBLE_VHT << 6 |
6328 (*nss - 1) << 4 |
6329 (ffs(mask->control[band].vht_mcs[i]) - 1);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006330
Michal Kazior3ae54222015-03-31 10:49:20 +00006331 return 0;
6332 }
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006333 }
6334
Michal Kazior3ae54222015-03-31 10:49:20 +00006335 return -EINVAL;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006336}
6337
Michal Kazior3ae54222015-03-31 10:49:20 +00006338static int ath10k_mac_set_fixed_rate_params(struct ath10k_vif *arvif,
Rajkumar Manoharanbd4a41e2015-09-16 13:19:00 +05306339 u8 rate, u8 nss, u8 sgi, u8 ldpc)
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006340{
6341 struct ath10k *ar = arvif->ar;
6342 u32 vdev_param;
Michal Kazior3ae54222015-03-31 10:49:20 +00006343 int ret;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006344
Michal Kazior3ae54222015-03-31 10:49:20 +00006345 lockdep_assert_held(&ar->conf_mutex);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006346
Michal Kazior3ae54222015-03-31 10:49:20 +00006347 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac set fixed rate params vdev %i rate 0x%02hhx nss %hhu sgi %hhu\n",
6348 arvif->vdev_id, rate, nss, sgi);
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01006349
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006350 vdev_param = ar->wmi.vdev_param->fixed_rate;
Michal Kazior3ae54222015-03-31 10:49:20 +00006351 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param, rate);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006352 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02006353 ath10k_warn(ar, "failed to set fixed rate param 0x%02x: %d\n",
Michal Kazior3ae54222015-03-31 10:49:20 +00006354 rate, ret);
6355 return ret;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006356 }
6357
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006358 vdev_param = ar->wmi.vdev_param->nss;
Michal Kazior3ae54222015-03-31 10:49:20 +00006359 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param, nss);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006360 if (ret) {
Michal Kazior3ae54222015-03-31 10:49:20 +00006361 ath10k_warn(ar, "failed to set nss param %d: %d\n", nss, ret);
6362 return ret;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006363 }
6364
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01006365 vdev_param = ar->wmi.vdev_param->sgi;
Michal Kazior3ae54222015-03-31 10:49:20 +00006366 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param, sgi);
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01006367 if (ret) {
Michal Kazior3ae54222015-03-31 10:49:20 +00006368 ath10k_warn(ar, "failed to set sgi param %d: %d\n", sgi, ret);
6369 return ret;
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01006370 }
6371
Rajkumar Manoharanbd4a41e2015-09-16 13:19:00 +05306372 vdev_param = ar->wmi.vdev_param->ldpc;
6373 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param, ldpc);
6374 if (ret) {
6375 ath10k_warn(ar, "failed to set ldpc param %d: %d\n", ldpc, ret);
6376 return ret;
6377 }
6378
Michal Kazior3ae54222015-03-31 10:49:20 +00006379 return 0;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006380}
6381
Michal Kazior45c9abc2015-04-21 20:42:58 +03006382static bool
6383ath10k_mac_can_set_bitrate_mask(struct ath10k *ar,
6384 enum ieee80211_band band,
6385 const struct cfg80211_bitrate_mask *mask)
6386{
6387 int i;
6388 u16 vht_mcs;
6389
6390 /* Due to firmware limitation in WMI_PEER_ASSOC_CMDID it is impossible
6391 * to express all VHT MCS rate masks. Effectively only the following
6392 * ranges can be used: none, 0-7, 0-8 and 0-9.
6393 */
6394 for (i = 0; i < NL80211_VHT_NSS_MAX; i++) {
6395 vht_mcs = mask->control[band].vht_mcs[i];
6396
6397 switch (vht_mcs) {
6398 case 0:
6399 case BIT(8) - 1:
6400 case BIT(9) - 1:
6401 case BIT(10) - 1:
6402 break;
6403 default:
6404 ath10k_warn(ar, "refusing bitrate mask with missing 0-7 VHT MCS rates\n");
6405 return false;
6406 }
6407 }
6408
6409 return true;
6410}
6411
6412static void ath10k_mac_set_bitrate_mask_iter(void *data,
6413 struct ieee80211_sta *sta)
6414{
6415 struct ath10k_vif *arvif = data;
6416 struct ath10k_sta *arsta = (struct ath10k_sta *)sta->drv_priv;
6417 struct ath10k *ar = arvif->ar;
6418
6419 if (arsta->arvif != arvif)
6420 return;
6421
6422 spin_lock_bh(&ar->data_lock);
6423 arsta->changed |= IEEE80211_RC_SUPP_RATES_CHANGED;
6424 spin_unlock_bh(&ar->data_lock);
6425
6426 ieee80211_queue_work(ar->hw, &arsta->update_wk);
6427}
6428
Michal Kazior3ae54222015-03-31 10:49:20 +00006429static int ath10k_mac_op_set_bitrate_mask(struct ieee80211_hw *hw,
6430 struct ieee80211_vif *vif,
6431 const struct cfg80211_bitrate_mask *mask)
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006432{
6433 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kazior500ff9f2015-03-31 10:26:21 +00006434 struct cfg80211_chan_def def;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006435 struct ath10k *ar = arvif->ar;
Michal Kazior500ff9f2015-03-31 10:26:21 +00006436 enum ieee80211_band band;
Michal Kazior45c9abc2015-04-21 20:42:58 +03006437 const u8 *ht_mcs_mask;
6438 const u16 *vht_mcs_mask;
Michal Kazior3ae54222015-03-31 10:49:20 +00006439 u8 rate;
6440 u8 nss;
6441 u8 sgi;
Rajkumar Manoharanbd4a41e2015-09-16 13:19:00 +05306442 u8 ldpc;
Michal Kazior3ae54222015-03-31 10:49:20 +00006443 int single_nss;
6444 int ret;
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01006445
Michal Kazior500ff9f2015-03-31 10:26:21 +00006446 if (ath10k_mac_vif_chan(vif, &def))
6447 return -EPERM;
6448
Michal Kazior500ff9f2015-03-31 10:26:21 +00006449 band = def.chan->band;
Michal Kazior45c9abc2015-04-21 20:42:58 +03006450 ht_mcs_mask = mask->control[band].ht_mcs;
6451 vht_mcs_mask = mask->control[band].vht_mcs;
Rajkumar Manoharanbd4a41e2015-09-16 13:19:00 +05306452 ldpc = !!(ar->ht_cap_info & WMI_HT_CAP_LDPC);
Michal Kazior500ff9f2015-03-31 10:26:21 +00006453
Michal Kazior3ae54222015-03-31 10:49:20 +00006454 sgi = mask->control[band].gi;
6455 if (sgi == NL80211_TXRATE_FORCE_LGI)
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01006456 return -EINVAL;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006457
Michal Kazior3ae54222015-03-31 10:49:20 +00006458 if (ath10k_mac_bitrate_mask_has_single_rate(ar, band, mask)) {
6459 ret = ath10k_mac_bitrate_mask_get_single_rate(ar, band, mask,
6460 &rate, &nss);
6461 if (ret) {
6462 ath10k_warn(ar, "failed to get single rate for vdev %i: %d\n",
6463 arvif->vdev_id, ret);
6464 return ret;
6465 }
6466 } else if (ath10k_mac_bitrate_mask_get_single_nss(ar, band, mask,
6467 &single_nss)) {
6468 rate = WMI_FIXED_RATE_NONE;
6469 nss = single_nss;
6470 } else {
6471 rate = WMI_FIXED_RATE_NONE;
Michal Kazior45c9abc2015-04-21 20:42:58 +03006472 nss = min(ar->num_rf_chains,
6473 max(ath10k_mac_max_ht_nss(ht_mcs_mask),
6474 ath10k_mac_max_vht_nss(vht_mcs_mask)));
6475
6476 if (!ath10k_mac_can_set_bitrate_mask(ar, band, mask))
6477 return -EINVAL;
6478
6479 mutex_lock(&ar->conf_mutex);
6480
6481 arvif->bitrate_mask = *mask;
6482 ieee80211_iterate_stations_atomic(ar->hw,
6483 ath10k_mac_set_bitrate_mask_iter,
6484 arvif);
6485
6486 mutex_unlock(&ar->conf_mutex);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006487 }
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006488
6489 mutex_lock(&ar->conf_mutex);
6490
Rajkumar Manoharanbd4a41e2015-09-16 13:19:00 +05306491 ret = ath10k_mac_set_fixed_rate_params(arvif, rate, nss, sgi, ldpc);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006492 if (ret) {
Michal Kazior3ae54222015-03-31 10:49:20 +00006493 ath10k_warn(ar, "failed to set fixed rate params on vdev %i: %d\n",
6494 arvif->vdev_id, ret);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006495 goto exit;
6496 }
6497
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006498exit:
6499 mutex_unlock(&ar->conf_mutex);
Michal Kazior3ae54222015-03-31 10:49:20 +00006500
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006501 return ret;
6502}
6503
Michal Kazior9797feb2014-02-14 14:49:48 +01006504static void ath10k_sta_rc_update(struct ieee80211_hw *hw,
6505 struct ieee80211_vif *vif,
6506 struct ieee80211_sta *sta,
6507 u32 changed)
6508{
6509 struct ath10k *ar = hw->priv;
6510 struct ath10k_sta *arsta = (struct ath10k_sta *)sta->drv_priv;
6511 u32 bw, smps;
6512
6513 spin_lock_bh(&ar->data_lock);
6514
Michal Kazior7aa7a722014-08-25 12:09:38 +02006515 ath10k_dbg(ar, ATH10K_DBG_MAC,
Michal Kazior9797feb2014-02-14 14:49:48 +01006516 "mac sta rc update for %pM changed %08x bw %d nss %d smps %d\n",
6517 sta->addr, changed, sta->bandwidth, sta->rx_nss,
6518 sta->smps_mode);
6519
6520 if (changed & IEEE80211_RC_BW_CHANGED) {
6521 bw = WMI_PEER_CHWIDTH_20MHZ;
6522
6523 switch (sta->bandwidth) {
6524 case IEEE80211_STA_RX_BW_20:
6525 bw = WMI_PEER_CHWIDTH_20MHZ;
6526 break;
6527 case IEEE80211_STA_RX_BW_40:
6528 bw = WMI_PEER_CHWIDTH_40MHZ;
6529 break;
6530 case IEEE80211_STA_RX_BW_80:
6531 bw = WMI_PEER_CHWIDTH_80MHZ;
6532 break;
6533 case IEEE80211_STA_RX_BW_160:
Masanari Iidad939be32015-02-27 23:52:31 +09006534 ath10k_warn(ar, "Invalid bandwidth %d in rc update for %pM\n",
Kalle Valobe6546f2014-03-25 14:18:51 +02006535 sta->bandwidth, sta->addr);
Michal Kazior9797feb2014-02-14 14:49:48 +01006536 bw = WMI_PEER_CHWIDTH_20MHZ;
6537 break;
6538 }
6539
6540 arsta->bw = bw;
6541 }
6542
6543 if (changed & IEEE80211_RC_NSS_CHANGED)
6544 arsta->nss = sta->rx_nss;
6545
6546 if (changed & IEEE80211_RC_SMPS_CHANGED) {
6547 smps = WMI_PEER_SMPS_PS_NONE;
6548
6549 switch (sta->smps_mode) {
6550 case IEEE80211_SMPS_AUTOMATIC:
6551 case IEEE80211_SMPS_OFF:
6552 smps = WMI_PEER_SMPS_PS_NONE;
6553 break;
6554 case IEEE80211_SMPS_STATIC:
6555 smps = WMI_PEER_SMPS_STATIC;
6556 break;
6557 case IEEE80211_SMPS_DYNAMIC:
6558 smps = WMI_PEER_SMPS_DYNAMIC;
6559 break;
6560 case IEEE80211_SMPS_NUM_MODES:
Michal Kazior7aa7a722014-08-25 12:09:38 +02006561 ath10k_warn(ar, "Invalid smps %d in sta rc update for %pM\n",
Kalle Valobe6546f2014-03-25 14:18:51 +02006562 sta->smps_mode, sta->addr);
Michal Kazior9797feb2014-02-14 14:49:48 +01006563 smps = WMI_PEER_SMPS_PS_NONE;
6564 break;
6565 }
6566
6567 arsta->smps = smps;
6568 }
6569
Michal Kazior9797feb2014-02-14 14:49:48 +01006570 arsta->changed |= changed;
6571
6572 spin_unlock_bh(&ar->data_lock);
6573
6574 ieee80211_queue_work(hw, &arsta->update_wk);
6575}
6576
Chun-Yeow Yeoh26ebbcc2014-02-25 09:29:54 +02006577static u64 ath10k_get_tsf(struct ieee80211_hw *hw, struct ieee80211_vif *vif)
6578{
6579 /*
6580 * FIXME: Return 0 for time being. Need to figure out whether FW
6581 * has the API to fetch 64-bit local TSF
6582 */
6583
6584 return 0;
6585}
6586
Michal Kazioraa5b4fb2014-07-23 12:20:33 +02006587static int ath10k_ampdu_action(struct ieee80211_hw *hw,
6588 struct ieee80211_vif *vif,
Sara Sharon50ea05e2015-12-30 16:06:04 +02006589 struct ieee80211_ampdu_params *params)
Michal Kazioraa5b4fb2014-07-23 12:20:33 +02006590{
Michal Kazior7aa7a722014-08-25 12:09:38 +02006591 struct ath10k *ar = hw->priv;
Michal Kazioraa5b4fb2014-07-23 12:20:33 +02006592 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Sara Sharon50ea05e2015-12-30 16:06:04 +02006593 struct ieee80211_sta *sta = params->sta;
6594 enum ieee80211_ampdu_mlme_action action = params->action;
6595 u16 tid = params->tid;
Michal Kazioraa5b4fb2014-07-23 12:20:33 +02006596
Michal Kazior7aa7a722014-08-25 12:09:38 +02006597 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 +02006598 arvif->vdev_id, sta->addr, tid, action);
6599
6600 switch (action) {
6601 case IEEE80211_AMPDU_RX_START:
6602 case IEEE80211_AMPDU_RX_STOP:
6603 /* HTT AddBa/DelBa events trigger mac80211 Rx BA session
6604 * creation/removal. Do we need to verify this?
6605 */
6606 return 0;
6607 case IEEE80211_AMPDU_TX_START:
6608 case IEEE80211_AMPDU_TX_STOP_CONT:
6609 case IEEE80211_AMPDU_TX_STOP_FLUSH:
6610 case IEEE80211_AMPDU_TX_STOP_FLUSH_CONT:
6611 case IEEE80211_AMPDU_TX_OPERATIONAL:
6612 /* Firmware offloads Tx aggregation entirely so deny mac80211
6613 * Tx aggregation requests.
6614 */
6615 return -EOPNOTSUPP;
6616 }
6617
6618 return -EINVAL;
6619}
6620
Michal Kazior500ff9f2015-03-31 10:26:21 +00006621static void
Michal Kaziord7bf4b42015-06-03 12:16:54 +02006622ath10k_mac_update_rx_channel(struct ath10k *ar,
6623 struct ieee80211_chanctx_conf *ctx,
6624 struct ieee80211_vif_chanctx_switch *vifs,
6625 int n_vifs)
Michal Kazior500ff9f2015-03-31 10:26:21 +00006626{
6627 struct cfg80211_chan_def *def = NULL;
6628
6629 /* Both locks are required because ar->rx_channel is modified. This
6630 * allows readers to hold either lock.
6631 */
6632 lockdep_assert_held(&ar->conf_mutex);
6633 lockdep_assert_held(&ar->data_lock);
6634
Michal Kaziord7bf4b42015-06-03 12:16:54 +02006635 WARN_ON(ctx && vifs);
6636 WARN_ON(vifs && n_vifs != 1);
6637
Michal Kazior500ff9f2015-03-31 10:26:21 +00006638 /* FIXME: Sort of an optimization and a workaround. Peers and vifs are
6639 * on a linked list now. Doing a lookup peer -> vif -> chanctx for each
6640 * ppdu on Rx may reduce performance on low-end systems. It should be
6641 * possible to make tables/hashmaps to speed the lookup up (be vary of
6642 * cpu data cache lines though regarding sizes) but to keep the initial
6643 * implementation simple and less intrusive fallback to the slow lookup
6644 * only for multi-channel cases. Single-channel cases will remain to
6645 * use the old channel derival and thus performance should not be
6646 * affected much.
6647 */
6648 rcu_read_lock();
Michal Kaziord7bf4b42015-06-03 12:16:54 +02006649 if (!ctx && ath10k_mac_num_chanctxs(ar) == 1) {
Michal Kazior500ff9f2015-03-31 10:26:21 +00006650 ieee80211_iter_chan_contexts_atomic(ar->hw,
Kalle Valo617b0f42015-10-05 17:56:35 +03006651 ath10k_mac_get_any_chandef_iter,
6652 &def);
Michal Kaziord7bf4b42015-06-03 12:16:54 +02006653
6654 if (vifs)
6655 def = &vifs[0].new_ctx->def;
6656
Michal Kazior500ff9f2015-03-31 10:26:21 +00006657 ar->rx_channel = def->chan;
Michal Kaziord7bf4b42015-06-03 12:16:54 +02006658 } else if (ctx && ath10k_mac_num_chanctxs(ar) == 0) {
6659 ar->rx_channel = ctx->def.chan;
Michal Kazior500ff9f2015-03-31 10:26:21 +00006660 } else {
6661 ar->rx_channel = NULL;
6662 }
6663 rcu_read_unlock();
6664}
6665
Michal Kazior7be6d1b2015-09-03 10:44:51 +02006666static void
6667ath10k_mac_update_vif_chan(struct ath10k *ar,
6668 struct ieee80211_vif_chanctx_switch *vifs,
6669 int n_vifs)
6670{
6671 struct ath10k_vif *arvif;
6672 int ret;
6673 int i;
6674
6675 lockdep_assert_held(&ar->conf_mutex);
6676
6677 /* First stop monitor interface. Some FW versions crash if there's a
6678 * lone monitor interface.
6679 */
6680 if (ar->monitor_started)
6681 ath10k_monitor_stop(ar);
6682
6683 for (i = 0; i < n_vifs; i++) {
6684 arvif = ath10k_vif_to_arvif(vifs[i].vif);
6685
6686 ath10k_dbg(ar, ATH10K_DBG_MAC,
6687 "mac chanctx switch vdev_id %i freq %hu->%hu width %d->%d\n",
6688 arvif->vdev_id,
6689 vifs[i].old_ctx->def.chan->center_freq,
6690 vifs[i].new_ctx->def.chan->center_freq,
6691 vifs[i].old_ctx->def.width,
6692 vifs[i].new_ctx->def.width);
6693
6694 if (WARN_ON(!arvif->is_started))
6695 continue;
6696
6697 if (WARN_ON(!arvif->is_up))
6698 continue;
6699
6700 ret = ath10k_wmi_vdev_down(ar, arvif->vdev_id);
6701 if (ret) {
6702 ath10k_warn(ar, "failed to down vdev %d: %d\n",
6703 arvif->vdev_id, ret);
6704 continue;
6705 }
6706 }
6707
6708 /* All relevant vdevs are downed and associated channel resources
6709 * should be available for the channel switch now.
6710 */
6711
6712 spin_lock_bh(&ar->data_lock);
6713 ath10k_mac_update_rx_channel(ar, NULL, vifs, n_vifs);
6714 spin_unlock_bh(&ar->data_lock);
6715
6716 for (i = 0; i < n_vifs; i++) {
6717 arvif = ath10k_vif_to_arvif(vifs[i].vif);
6718
6719 if (WARN_ON(!arvif->is_started))
6720 continue;
6721
6722 if (WARN_ON(!arvif->is_up))
6723 continue;
6724
6725 ret = ath10k_mac_setup_bcn_tmpl(arvif);
6726 if (ret)
6727 ath10k_warn(ar, "failed to update bcn tmpl during csa: %d\n",
6728 ret);
6729
6730 ret = ath10k_mac_setup_prb_tmpl(arvif);
6731 if (ret)
6732 ath10k_warn(ar, "failed to update prb tmpl during csa: %d\n",
6733 ret);
6734
6735 ret = ath10k_vdev_restart(arvif, &vifs[i].new_ctx->def);
6736 if (ret) {
6737 ath10k_warn(ar, "failed to restart vdev %d: %d\n",
6738 arvif->vdev_id, ret);
6739 continue;
6740 }
6741
6742 ret = ath10k_wmi_vdev_up(arvif->ar, arvif->vdev_id, arvif->aid,
6743 arvif->bssid);
6744 if (ret) {
6745 ath10k_warn(ar, "failed to bring vdev up %d: %d\n",
6746 arvif->vdev_id, ret);
6747 continue;
6748 }
6749 }
6750
6751 ath10k_monitor_recalc(ar);
6752}
6753
Michal Kazior500ff9f2015-03-31 10:26:21 +00006754static int
6755ath10k_mac_op_add_chanctx(struct ieee80211_hw *hw,
6756 struct ieee80211_chanctx_conf *ctx)
6757{
6758 struct ath10k *ar = hw->priv;
Michal Kazior500ff9f2015-03-31 10:26:21 +00006759
6760 ath10k_dbg(ar, ATH10K_DBG_MAC,
6761 "mac chanctx add freq %hu width %d ptr %p\n",
6762 ctx->def.chan->center_freq, ctx->def.width, ctx);
6763
6764 mutex_lock(&ar->conf_mutex);
6765
6766 spin_lock_bh(&ar->data_lock);
Michal Kaziord7bf4b42015-06-03 12:16:54 +02006767 ath10k_mac_update_rx_channel(ar, ctx, NULL, 0);
Michal Kazior500ff9f2015-03-31 10:26:21 +00006768 spin_unlock_bh(&ar->data_lock);
6769
6770 ath10k_recalc_radar_detection(ar);
6771 ath10k_monitor_recalc(ar);
6772
6773 mutex_unlock(&ar->conf_mutex);
6774
6775 return 0;
6776}
6777
6778static void
6779ath10k_mac_op_remove_chanctx(struct ieee80211_hw *hw,
6780 struct ieee80211_chanctx_conf *ctx)
6781{
6782 struct ath10k *ar = hw->priv;
6783
6784 ath10k_dbg(ar, ATH10K_DBG_MAC,
6785 "mac chanctx remove freq %hu width %d ptr %p\n",
6786 ctx->def.chan->center_freq, ctx->def.width, ctx);
6787
6788 mutex_lock(&ar->conf_mutex);
6789
6790 spin_lock_bh(&ar->data_lock);
Michal Kaziord7bf4b42015-06-03 12:16:54 +02006791 ath10k_mac_update_rx_channel(ar, NULL, NULL, 0);
Michal Kazior500ff9f2015-03-31 10:26:21 +00006792 spin_unlock_bh(&ar->data_lock);
6793
6794 ath10k_recalc_radar_detection(ar);
6795 ath10k_monitor_recalc(ar);
6796
6797 mutex_unlock(&ar->conf_mutex);
6798}
6799
Michal Kazior9713e3d2015-09-03 10:44:52 +02006800struct ath10k_mac_change_chanctx_arg {
6801 struct ieee80211_chanctx_conf *ctx;
6802 struct ieee80211_vif_chanctx_switch *vifs;
6803 int n_vifs;
6804 int next_vif;
6805};
6806
6807static void
6808ath10k_mac_change_chanctx_cnt_iter(void *data, u8 *mac,
6809 struct ieee80211_vif *vif)
6810{
6811 struct ath10k_mac_change_chanctx_arg *arg = data;
6812
6813 if (rcu_access_pointer(vif->chanctx_conf) != arg->ctx)
6814 return;
6815
6816 arg->n_vifs++;
6817}
6818
6819static void
6820ath10k_mac_change_chanctx_fill_iter(void *data, u8 *mac,
6821 struct ieee80211_vif *vif)
6822{
6823 struct ath10k_mac_change_chanctx_arg *arg = data;
6824 struct ieee80211_chanctx_conf *ctx;
6825
6826 ctx = rcu_access_pointer(vif->chanctx_conf);
6827 if (ctx != arg->ctx)
6828 return;
6829
6830 if (WARN_ON(arg->next_vif == arg->n_vifs))
6831 return;
6832
6833 arg->vifs[arg->next_vif].vif = vif;
6834 arg->vifs[arg->next_vif].old_ctx = ctx;
6835 arg->vifs[arg->next_vif].new_ctx = ctx;
6836 arg->next_vif++;
6837}
6838
Michal Kazior500ff9f2015-03-31 10:26:21 +00006839static void
6840ath10k_mac_op_change_chanctx(struct ieee80211_hw *hw,
6841 struct ieee80211_chanctx_conf *ctx,
6842 u32 changed)
6843{
6844 struct ath10k *ar = hw->priv;
Michal Kazior9713e3d2015-09-03 10:44:52 +02006845 struct ath10k_mac_change_chanctx_arg arg = { .ctx = ctx };
Michal Kazior500ff9f2015-03-31 10:26:21 +00006846
6847 mutex_lock(&ar->conf_mutex);
6848
6849 ath10k_dbg(ar, ATH10K_DBG_MAC,
Michal Kazior089ab7a2015-06-03 12:16:55 +02006850 "mac chanctx change freq %hu width %d ptr %p changed %x\n",
6851 ctx->def.chan->center_freq, ctx->def.width, ctx, changed);
Michal Kazior500ff9f2015-03-31 10:26:21 +00006852
6853 /* This shouldn't really happen because channel switching should use
6854 * switch_vif_chanctx().
6855 */
6856 if (WARN_ON(changed & IEEE80211_CHANCTX_CHANGE_CHANNEL))
6857 goto unlock;
6858
Michal Kazior9713e3d2015-09-03 10:44:52 +02006859 if (changed & IEEE80211_CHANCTX_CHANGE_WIDTH) {
6860 ieee80211_iterate_active_interfaces_atomic(
6861 hw,
6862 IEEE80211_IFACE_ITER_NORMAL,
6863 ath10k_mac_change_chanctx_cnt_iter,
6864 &arg);
6865 if (arg.n_vifs == 0)
6866 goto radar;
6867
6868 arg.vifs = kcalloc(arg.n_vifs, sizeof(arg.vifs[0]),
6869 GFP_KERNEL);
6870 if (!arg.vifs)
6871 goto radar;
6872
6873 ieee80211_iterate_active_interfaces_atomic(
6874 hw,
6875 IEEE80211_IFACE_ITER_NORMAL,
6876 ath10k_mac_change_chanctx_fill_iter,
6877 &arg);
6878 ath10k_mac_update_vif_chan(ar, arg.vifs, arg.n_vifs);
6879 kfree(arg.vifs);
6880 }
6881
6882radar:
Michal Kazior500ff9f2015-03-31 10:26:21 +00006883 ath10k_recalc_radar_detection(ar);
6884
6885 /* FIXME: How to configure Rx chains properly? */
6886
6887 /* No other actions are actually necessary. Firmware maintains channel
6888 * definitions per vdev internally and there's no host-side channel
6889 * context abstraction to configure, e.g. channel width.
6890 */
6891
6892unlock:
6893 mutex_unlock(&ar->conf_mutex);
6894}
6895
6896static int
6897ath10k_mac_op_assign_vif_chanctx(struct ieee80211_hw *hw,
6898 struct ieee80211_vif *vif,
6899 struct ieee80211_chanctx_conf *ctx)
6900{
6901 struct ath10k *ar = hw->priv;
Michal Kazior500ff9f2015-03-31 10:26:21 +00006902 struct ath10k_vif *arvif = (void *)vif->drv_priv;
6903 int ret;
6904
6905 mutex_lock(&ar->conf_mutex);
6906
6907 ath10k_dbg(ar, ATH10K_DBG_MAC,
6908 "mac chanctx assign ptr %p vdev_id %i\n",
6909 ctx, arvif->vdev_id);
6910
6911 if (WARN_ON(arvif->is_started)) {
6912 mutex_unlock(&ar->conf_mutex);
6913 return -EBUSY;
6914 }
6915
Michal Kazior089ab7a2015-06-03 12:16:55 +02006916 ret = ath10k_vdev_start(arvif, &ctx->def);
Michal Kazior500ff9f2015-03-31 10:26:21 +00006917 if (ret) {
6918 ath10k_warn(ar, "failed to start vdev %i addr %pM on freq %d: %d\n",
6919 arvif->vdev_id, vif->addr,
Michal Kazior089ab7a2015-06-03 12:16:55 +02006920 ctx->def.chan->center_freq, ret);
Michal Kazior500ff9f2015-03-31 10:26:21 +00006921 goto err;
6922 }
6923
6924 arvif->is_started = true;
6925
Michal Kaziorf23e587e2015-07-09 13:08:37 +02006926 ret = ath10k_mac_vif_setup_ps(arvif);
6927 if (ret) {
6928 ath10k_warn(ar, "failed to update vdev %i ps: %d\n",
6929 arvif->vdev_id, ret);
6930 goto err_stop;
6931 }
6932
Michal Kazior500ff9f2015-03-31 10:26:21 +00006933 if (vif->type == NL80211_IFTYPE_MONITOR) {
6934 ret = ath10k_wmi_vdev_up(ar, arvif->vdev_id, 0, vif->addr);
6935 if (ret) {
6936 ath10k_warn(ar, "failed to up monitor vdev %i: %d\n",
6937 arvif->vdev_id, ret);
6938 goto err_stop;
6939 }
6940
6941 arvif->is_up = true;
6942 }
6943
6944 mutex_unlock(&ar->conf_mutex);
6945 return 0;
6946
6947err_stop:
6948 ath10k_vdev_stop(arvif);
6949 arvif->is_started = false;
Michal Kaziorf23e587e2015-07-09 13:08:37 +02006950 ath10k_mac_vif_setup_ps(arvif);
Michal Kazior500ff9f2015-03-31 10:26:21 +00006951
6952err:
6953 mutex_unlock(&ar->conf_mutex);
6954 return ret;
6955}
6956
6957static void
6958ath10k_mac_op_unassign_vif_chanctx(struct ieee80211_hw *hw,
6959 struct ieee80211_vif *vif,
6960 struct ieee80211_chanctx_conf *ctx)
6961{
6962 struct ath10k *ar = hw->priv;
6963 struct ath10k_vif *arvif = (void *)vif->drv_priv;
6964 int ret;
6965
6966 mutex_lock(&ar->conf_mutex);
6967
6968 ath10k_dbg(ar, ATH10K_DBG_MAC,
6969 "mac chanctx unassign ptr %p vdev_id %i\n",
6970 ctx, arvif->vdev_id);
6971
6972 WARN_ON(!arvif->is_started);
6973
6974 if (vif->type == NL80211_IFTYPE_MONITOR) {
6975 WARN_ON(!arvif->is_up);
6976
6977 ret = ath10k_wmi_vdev_down(ar, arvif->vdev_id);
6978 if (ret)
6979 ath10k_warn(ar, "failed to down monitor vdev %i: %d\n",
6980 arvif->vdev_id, ret);
6981
6982 arvif->is_up = false;
6983 }
6984
6985 ret = ath10k_vdev_stop(arvif);
6986 if (ret)
6987 ath10k_warn(ar, "failed to stop vdev %i: %d\n",
6988 arvif->vdev_id, ret);
6989
6990 arvif->is_started = false;
6991
6992 mutex_unlock(&ar->conf_mutex);
6993}
6994
6995static int
6996ath10k_mac_op_switch_vif_chanctx(struct ieee80211_hw *hw,
6997 struct ieee80211_vif_chanctx_switch *vifs,
6998 int n_vifs,
6999 enum ieee80211_chanctx_switch_mode mode)
7000{
7001 struct ath10k *ar = hw->priv;
Michal Kazior500ff9f2015-03-31 10:26:21 +00007002
7003 mutex_lock(&ar->conf_mutex);
7004
7005 ath10k_dbg(ar, ATH10K_DBG_MAC,
7006 "mac chanctx switch n_vifs %d mode %d\n",
7007 n_vifs, mode);
Michal Kazior7be6d1b2015-09-03 10:44:51 +02007008 ath10k_mac_update_vif_chan(ar, vifs, n_vifs);
Michal Kazior500ff9f2015-03-31 10:26:21 +00007009
7010 mutex_unlock(&ar->conf_mutex);
7011 return 0;
7012}
7013
Kalle Valo5e3dd152013-06-12 20:52:10 +03007014static const struct ieee80211_ops ath10k_ops = {
Michal Kaziorf2f6eca2016-03-01 11:32:46 +01007015 .tx = ath10k_mac_op_tx,
Kalle Valo5e3dd152013-06-12 20:52:10 +03007016 .start = ath10k_start,
7017 .stop = ath10k_stop,
7018 .config = ath10k_config,
7019 .add_interface = ath10k_add_interface,
7020 .remove_interface = ath10k_remove_interface,
7021 .configure_filter = ath10k_configure_filter,
7022 .bss_info_changed = ath10k_bss_info_changed,
7023 .hw_scan = ath10k_hw_scan,
7024 .cancel_hw_scan = ath10k_cancel_hw_scan,
7025 .set_key = ath10k_set_key,
SenthilKumar Jegadeesan627613f2015-01-29 13:50:38 +02007026 .set_default_unicast_key = ath10k_set_default_unicast_key,
Kalle Valo5e3dd152013-06-12 20:52:10 +03007027 .sta_state = ath10k_sta_state,
7028 .conf_tx = ath10k_conf_tx,
7029 .remain_on_channel = ath10k_remain_on_channel,
7030 .cancel_remain_on_channel = ath10k_cancel_remain_on_channel,
7031 .set_rts_threshold = ath10k_set_rts_threshold,
Michal Kazior92092fe2015-08-03 11:16:43 +02007032 .set_frag_threshold = ath10k_mac_op_set_frag_threshold,
Kalle Valo5e3dd152013-06-12 20:52:10 +03007033 .flush = ath10k_flush,
7034 .tx_last_beacon = ath10k_tx_last_beacon,
Ben Greear46acf7b2014-05-16 17:15:38 +03007035 .set_antenna = ath10k_set_antenna,
7036 .get_antenna = ath10k_get_antenna,
Eliad Pellercf2c92d2014-11-04 11:43:54 +02007037 .reconfig_complete = ath10k_reconfig_complete,
Michal Kazior2e1dea42013-07-31 10:32:40 +02007038 .get_survey = ath10k_get_survey,
Michal Kazior3ae54222015-03-31 10:49:20 +00007039 .set_bitrate_mask = ath10k_mac_op_set_bitrate_mask,
Michal Kazior9797feb2014-02-14 14:49:48 +01007040 .sta_rc_update = ath10k_sta_rc_update,
Chun-Yeow Yeoh26ebbcc2014-02-25 09:29:54 +02007041 .get_tsf = ath10k_get_tsf,
Michal Kazioraa5b4fb2014-07-23 12:20:33 +02007042 .ampdu_action = ath10k_ampdu_action,
Ben Greear6cddcc72014-09-29 14:41:46 +03007043 .get_et_sset_count = ath10k_debug_get_et_sset_count,
7044 .get_et_stats = ath10k_debug_get_et_stats,
7045 .get_et_strings = ath10k_debug_get_et_strings,
Michal Kazior500ff9f2015-03-31 10:26:21 +00007046 .add_chanctx = ath10k_mac_op_add_chanctx,
7047 .remove_chanctx = ath10k_mac_op_remove_chanctx,
7048 .change_chanctx = ath10k_mac_op_change_chanctx,
7049 .assign_vif_chanctx = ath10k_mac_op_assign_vif_chanctx,
7050 .unassign_vif_chanctx = ath10k_mac_op_unassign_vif_chanctx,
7051 .switch_vif_chanctx = ath10k_mac_op_switch_vif_chanctx,
Kalle Valo43d2a302014-09-10 18:23:30 +03007052
7053 CFG80211_TESTMODE_CMD(ath10k_tm_cmd)
7054
Michal Kazior8cd13ca2013-07-16 09:38:54 +02007055#ifdef CONFIG_PM
Janusz Dziedzic5fd3ac32015-03-23 17:32:53 +02007056 .suspend = ath10k_wow_op_suspend,
7057 .resume = ath10k_wow_op_resume,
Michal Kazior8cd13ca2013-07-16 09:38:54 +02007058#endif
Rajkumar Manoharanf5045982015-01-12 14:07:27 +02007059#ifdef CONFIG_MAC80211_DEBUGFS
7060 .sta_add_debugfs = ath10k_sta_add_debugfs,
7061#endif
Kalle Valo5e3dd152013-06-12 20:52:10 +03007062};
7063
Kalle Valo5e3dd152013-06-12 20:52:10 +03007064#define CHAN2G(_channel, _freq, _flags) { \
7065 .band = IEEE80211_BAND_2GHZ, \
7066 .hw_value = (_channel), \
7067 .center_freq = (_freq), \
7068 .flags = (_flags), \
7069 .max_antenna_gain = 0, \
7070 .max_power = 30, \
7071}
7072
7073#define CHAN5G(_channel, _freq, _flags) { \
7074 .band = IEEE80211_BAND_5GHZ, \
7075 .hw_value = (_channel), \
7076 .center_freq = (_freq), \
7077 .flags = (_flags), \
7078 .max_antenna_gain = 0, \
7079 .max_power = 30, \
7080}
7081
7082static const struct ieee80211_channel ath10k_2ghz_channels[] = {
7083 CHAN2G(1, 2412, 0),
7084 CHAN2G(2, 2417, 0),
7085 CHAN2G(3, 2422, 0),
7086 CHAN2G(4, 2427, 0),
7087 CHAN2G(5, 2432, 0),
7088 CHAN2G(6, 2437, 0),
7089 CHAN2G(7, 2442, 0),
7090 CHAN2G(8, 2447, 0),
7091 CHAN2G(9, 2452, 0),
7092 CHAN2G(10, 2457, 0),
7093 CHAN2G(11, 2462, 0),
7094 CHAN2G(12, 2467, 0),
7095 CHAN2G(13, 2472, 0),
7096 CHAN2G(14, 2484, 0),
7097};
7098
7099static const struct ieee80211_channel ath10k_5ghz_channels[] = {
Michal Kazior429ff562013-06-26 08:54:54 +02007100 CHAN5G(36, 5180, 0),
7101 CHAN5G(40, 5200, 0),
7102 CHAN5G(44, 5220, 0),
7103 CHAN5G(48, 5240, 0),
7104 CHAN5G(52, 5260, 0),
7105 CHAN5G(56, 5280, 0),
7106 CHAN5G(60, 5300, 0),
7107 CHAN5G(64, 5320, 0),
7108 CHAN5G(100, 5500, 0),
7109 CHAN5G(104, 5520, 0),
7110 CHAN5G(108, 5540, 0),
7111 CHAN5G(112, 5560, 0),
7112 CHAN5G(116, 5580, 0),
7113 CHAN5G(120, 5600, 0),
7114 CHAN5G(124, 5620, 0),
7115 CHAN5G(128, 5640, 0),
7116 CHAN5G(132, 5660, 0),
7117 CHAN5G(136, 5680, 0),
7118 CHAN5G(140, 5700, 0),
Peter Oh4a7898f2015-03-18 11:39:18 -07007119 CHAN5G(144, 5720, 0),
Michal Kazior429ff562013-06-26 08:54:54 +02007120 CHAN5G(149, 5745, 0),
7121 CHAN5G(153, 5765, 0),
7122 CHAN5G(157, 5785, 0),
7123 CHAN5G(161, 5805, 0),
7124 CHAN5G(165, 5825, 0),
Kalle Valo5e3dd152013-06-12 20:52:10 +03007125};
7126
Michal Kaziore7b54192014-08-07 11:03:27 +02007127struct ath10k *ath10k_mac_create(size_t priv_size)
Kalle Valo5e3dd152013-06-12 20:52:10 +03007128{
7129 struct ieee80211_hw *hw;
7130 struct ath10k *ar;
7131
Michal Kaziore7b54192014-08-07 11:03:27 +02007132 hw = ieee80211_alloc_hw(sizeof(struct ath10k) + priv_size, &ath10k_ops);
Kalle Valo5e3dd152013-06-12 20:52:10 +03007133 if (!hw)
7134 return NULL;
7135
7136 ar = hw->priv;
7137 ar->hw = hw;
7138
7139 return ar;
7140}
7141
7142void ath10k_mac_destroy(struct ath10k *ar)
7143{
7144 ieee80211_free_hw(ar->hw);
7145}
7146
7147static const struct ieee80211_iface_limit ath10k_if_limits[] = {
7148 {
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05307149 .max = 8,
7150 .types = BIT(NL80211_IFTYPE_STATION)
7151 | BIT(NL80211_IFTYPE_P2P_CLIENT)
Michal Kaziord531cb82013-07-31 10:55:13 +02007152 },
7153 {
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05307154 .max = 3,
7155 .types = BIT(NL80211_IFTYPE_P2P_GO)
Michal Kaziord531cb82013-07-31 10:55:13 +02007156 },
7157 {
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05307158 .max = 1,
7159 .types = BIT(NL80211_IFTYPE_P2P_DEVICE)
Michal Kazior75d2bd42014-12-12 12:41:39 +01007160 },
7161 {
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05307162 .max = 7,
7163 .types = BIT(NL80211_IFTYPE_AP)
Bob Copelandb6c7baf2015-09-09 12:47:36 -04007164#ifdef CONFIG_MAC80211_MESH
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05307165 | BIT(NL80211_IFTYPE_MESH_POINT)
Bob Copelandb6c7baf2015-09-09 12:47:36 -04007166#endif
Michal Kaziord531cb82013-07-31 10:55:13 +02007167 },
Kalle Valo5e3dd152013-06-12 20:52:10 +03007168};
7169
Bartosz Markowskif2595092013-12-10 16:20:39 +01007170static const struct ieee80211_iface_limit ath10k_10x_if_limits[] = {
Marek Puzyniake8a50f82013-11-20 09:59:47 +02007171 {
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05307172 .max = 8,
7173 .types = BIT(NL80211_IFTYPE_AP)
Bob Copelandb6c7baf2015-09-09 12:47:36 -04007174#ifdef CONFIG_MAC80211_MESH
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05307175 | BIT(NL80211_IFTYPE_MESH_POINT)
Bob Copelandb6c7baf2015-09-09 12:47:36 -04007176#endif
Marek Puzyniake8a50f82013-11-20 09:59:47 +02007177 },
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05307178 {
7179 .max = 1,
7180 .types = BIT(NL80211_IFTYPE_STATION)
7181 },
Marek Puzyniake8a50f82013-11-20 09:59:47 +02007182};
Marek Puzyniake8a50f82013-11-20 09:59:47 +02007183
7184static const struct ieee80211_iface_combination ath10k_if_comb[] = {
7185 {
7186 .limits = ath10k_if_limits,
7187 .n_limits = ARRAY_SIZE(ath10k_if_limits),
7188 .max_interfaces = 8,
7189 .num_different_channels = 1,
7190 .beacon_int_infra_match = true,
7191 },
Bartosz Markowskif2595092013-12-10 16:20:39 +01007192};
7193
7194static const struct ieee80211_iface_combination ath10k_10x_if_comb[] = {
Marek Puzyniake8a50f82013-11-20 09:59:47 +02007195 {
Bartosz Markowskif2595092013-12-10 16:20:39 +01007196 .limits = ath10k_10x_if_limits,
7197 .n_limits = ARRAY_SIZE(ath10k_10x_if_limits),
Marek Puzyniake8a50f82013-11-20 09:59:47 +02007198 .max_interfaces = 8,
7199 .num_different_channels = 1,
7200 .beacon_int_infra_match = true,
Bartosz Markowskif2595092013-12-10 16:20:39 +01007201#ifdef CONFIG_ATH10K_DFS_CERTIFIED
Marek Puzyniake8a50f82013-11-20 09:59:47 +02007202 .radar_detect_widths = BIT(NL80211_CHAN_WIDTH_20_NOHT) |
7203 BIT(NL80211_CHAN_WIDTH_20) |
7204 BIT(NL80211_CHAN_WIDTH_40) |
7205 BIT(NL80211_CHAN_WIDTH_80),
Marek Puzyniake8a50f82013-11-20 09:59:47 +02007206#endif
Bartosz Markowskif2595092013-12-10 16:20:39 +01007207 },
Kalle Valo5e3dd152013-06-12 20:52:10 +03007208};
7209
Michal Kaziorcf327842015-03-31 10:26:25 +00007210static const struct ieee80211_iface_limit ath10k_tlv_if_limit[] = {
7211 {
7212 .max = 2,
Michal Kaziored25b112015-07-09 13:08:39 +02007213 .types = BIT(NL80211_IFTYPE_STATION),
7214 },
7215 {
7216 .max = 2,
7217 .types = BIT(NL80211_IFTYPE_AP) |
Bob Copelandb6c7baf2015-09-09 12:47:36 -04007218#ifdef CONFIG_MAC80211_MESH
7219 BIT(NL80211_IFTYPE_MESH_POINT) |
7220#endif
Michal Kaziorcf327842015-03-31 10:26:25 +00007221 BIT(NL80211_IFTYPE_P2P_CLIENT) |
7222 BIT(NL80211_IFTYPE_P2P_GO),
7223 },
7224 {
7225 .max = 1,
7226 .types = BIT(NL80211_IFTYPE_P2P_DEVICE),
7227 },
7228};
7229
Michal Kaziored25b112015-07-09 13:08:39 +02007230static const struct ieee80211_iface_limit ath10k_tlv_qcs_if_limit[] = {
7231 {
7232 .max = 2,
7233 .types = BIT(NL80211_IFTYPE_STATION),
7234 },
7235 {
7236 .max = 2,
7237 .types = BIT(NL80211_IFTYPE_P2P_CLIENT),
7238 },
7239 {
7240 .max = 1,
7241 .types = BIT(NL80211_IFTYPE_AP) |
Bob Copelandb6c7baf2015-09-09 12:47:36 -04007242#ifdef CONFIG_MAC80211_MESH
7243 BIT(NL80211_IFTYPE_MESH_POINT) |
7244#endif
Michal Kaziored25b112015-07-09 13:08:39 +02007245 BIT(NL80211_IFTYPE_P2P_GO),
7246 },
7247 {
7248 .max = 1,
7249 .types = BIT(NL80211_IFTYPE_P2P_DEVICE),
7250 },
7251};
7252
Michal Kaziorcf327842015-03-31 10:26:25 +00007253static const struct ieee80211_iface_limit ath10k_tlv_if_limit_ibss[] = {
7254 {
7255 .max = 1,
7256 .types = BIT(NL80211_IFTYPE_STATION),
7257 },
7258 {
7259 .max = 1,
7260 .types = BIT(NL80211_IFTYPE_ADHOC),
7261 },
7262};
7263
7264/* FIXME: This is not thouroughly tested. These combinations may over- or
7265 * underestimate hw/fw capabilities.
7266 */
7267static struct ieee80211_iface_combination ath10k_tlv_if_comb[] = {
7268 {
7269 .limits = ath10k_tlv_if_limit,
7270 .num_different_channels = 1,
Michal Kaziored25b112015-07-09 13:08:39 +02007271 .max_interfaces = 4,
Michal Kaziorcf327842015-03-31 10:26:25 +00007272 .n_limits = ARRAY_SIZE(ath10k_tlv_if_limit),
7273 },
7274 {
7275 .limits = ath10k_tlv_if_limit_ibss,
7276 .num_different_channels = 1,
7277 .max_interfaces = 2,
7278 .n_limits = ARRAY_SIZE(ath10k_tlv_if_limit_ibss),
7279 },
7280};
7281
7282static struct ieee80211_iface_combination ath10k_tlv_qcs_if_comb[] = {
7283 {
7284 .limits = ath10k_tlv_if_limit,
Michal Kaziored25b112015-07-09 13:08:39 +02007285 .num_different_channels = 1,
7286 .max_interfaces = 4,
Michal Kaziorcf327842015-03-31 10:26:25 +00007287 .n_limits = ARRAY_SIZE(ath10k_tlv_if_limit),
7288 },
7289 {
Michal Kaziored25b112015-07-09 13:08:39 +02007290 .limits = ath10k_tlv_qcs_if_limit,
7291 .num_different_channels = 2,
7292 .max_interfaces = 4,
7293 .n_limits = ARRAY_SIZE(ath10k_tlv_qcs_if_limit),
7294 },
7295 {
Michal Kaziorcf327842015-03-31 10:26:25 +00007296 .limits = ath10k_tlv_if_limit_ibss,
7297 .num_different_channels = 1,
7298 .max_interfaces = 2,
7299 .n_limits = ARRAY_SIZE(ath10k_tlv_if_limit_ibss),
7300 },
7301};
7302
Raja Manicf36fef2015-06-22 20:22:25 +05307303static const struct ieee80211_iface_limit ath10k_10_4_if_limits[] = {
7304 {
7305 .max = 1,
7306 .types = BIT(NL80211_IFTYPE_STATION),
7307 },
7308 {
7309 .max = 16,
7310 .types = BIT(NL80211_IFTYPE_AP)
Bob Copelandb6c7baf2015-09-09 12:47:36 -04007311#ifdef CONFIG_MAC80211_MESH
7312 | BIT(NL80211_IFTYPE_MESH_POINT)
7313#endif
Raja Manicf36fef2015-06-22 20:22:25 +05307314 },
7315};
7316
7317static const struct ieee80211_iface_combination ath10k_10_4_if_comb[] = {
7318 {
7319 .limits = ath10k_10_4_if_limits,
7320 .n_limits = ARRAY_SIZE(ath10k_10_4_if_limits),
7321 .max_interfaces = 16,
7322 .num_different_channels = 1,
7323 .beacon_int_infra_match = true,
7324#ifdef CONFIG_ATH10K_DFS_CERTIFIED
7325 .radar_detect_widths = BIT(NL80211_CHAN_WIDTH_20_NOHT) |
7326 BIT(NL80211_CHAN_WIDTH_20) |
7327 BIT(NL80211_CHAN_WIDTH_40) |
7328 BIT(NL80211_CHAN_WIDTH_80),
7329#endif
7330 },
7331};
7332
Kalle Valo5e3dd152013-06-12 20:52:10 +03007333static void ath10k_get_arvif_iter(void *data, u8 *mac,
7334 struct ieee80211_vif *vif)
7335{
7336 struct ath10k_vif_iter *arvif_iter = data;
7337 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
7338
7339 if (arvif->vdev_id == arvif_iter->vdev_id)
7340 arvif_iter->arvif = arvif;
7341}
7342
7343struct ath10k_vif *ath10k_get_arvif(struct ath10k *ar, u32 vdev_id)
7344{
7345 struct ath10k_vif_iter arvif_iter;
7346 u32 flags;
7347
7348 memset(&arvif_iter, 0, sizeof(struct ath10k_vif_iter));
7349 arvif_iter.vdev_id = vdev_id;
7350
7351 flags = IEEE80211_IFACE_ITER_RESUME_ALL;
7352 ieee80211_iterate_active_interfaces_atomic(ar->hw,
7353 flags,
7354 ath10k_get_arvif_iter,
7355 &arvif_iter);
7356 if (!arvif_iter.arvif) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02007357 ath10k_warn(ar, "No VIF found for vdev %d\n", vdev_id);
Kalle Valo5e3dd152013-06-12 20:52:10 +03007358 return NULL;
7359 }
7360
7361 return arvif_iter.arvif;
7362}
7363
7364int ath10k_mac_register(struct ath10k *ar)
7365{
Johannes Berg3cb10942015-01-22 21:38:45 +01007366 static const u32 cipher_suites[] = {
7367 WLAN_CIPHER_SUITE_WEP40,
7368 WLAN_CIPHER_SUITE_WEP104,
7369 WLAN_CIPHER_SUITE_TKIP,
7370 WLAN_CIPHER_SUITE_CCMP,
7371 WLAN_CIPHER_SUITE_AES_CMAC,
7372 };
Kalle Valo5e3dd152013-06-12 20:52:10 +03007373 struct ieee80211_supported_band *band;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007374 void *channels;
7375 int ret;
7376
7377 SET_IEEE80211_PERM_ADDR(ar->hw, ar->mac_addr);
7378
7379 SET_IEEE80211_DEV(ar->hw, ar->dev);
7380
Michal Kaziorc94aa7e2015-03-24 12:38:11 +00007381 BUILD_BUG_ON((ARRAY_SIZE(ath10k_2ghz_channels) +
7382 ARRAY_SIZE(ath10k_5ghz_channels)) !=
7383 ATH10K_NUM_CHANS);
7384
Kalle Valo5e3dd152013-06-12 20:52:10 +03007385 if (ar->phy_capability & WHAL_WLAN_11G_CAPABILITY) {
7386 channels = kmemdup(ath10k_2ghz_channels,
7387 sizeof(ath10k_2ghz_channels),
7388 GFP_KERNEL);
Michal Kaziord6015b22013-07-22 14:13:30 +02007389 if (!channels) {
7390 ret = -ENOMEM;
7391 goto err_free;
7392 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03007393
7394 band = &ar->mac.sbands[IEEE80211_BAND_2GHZ];
7395 band->n_channels = ARRAY_SIZE(ath10k_2ghz_channels);
7396 band->channels = channels;
7397 band->n_bitrates = ath10k_g_rates_size;
7398 band->bitrates = ath10k_g_rates;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007399
7400 ar->hw->wiphy->bands[IEEE80211_BAND_2GHZ] = band;
7401 }
7402
7403 if (ar->phy_capability & WHAL_WLAN_11A_CAPABILITY) {
7404 channels = kmemdup(ath10k_5ghz_channels,
7405 sizeof(ath10k_5ghz_channels),
7406 GFP_KERNEL);
7407 if (!channels) {
Michal Kaziord6015b22013-07-22 14:13:30 +02007408 ret = -ENOMEM;
7409 goto err_free;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007410 }
7411
7412 band = &ar->mac.sbands[IEEE80211_BAND_5GHZ];
7413 band->n_channels = ARRAY_SIZE(ath10k_5ghz_channels);
7414 band->channels = channels;
7415 band->n_bitrates = ath10k_a_rates_size;
7416 band->bitrates = ath10k_a_rates;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007417 ar->hw->wiphy->bands[IEEE80211_BAND_5GHZ] = band;
7418 }
7419
Rajkumar Manoharan5036fe02015-10-27 17:51:14 +05307420 ath10k_mac_setup_ht_vht_cap(ar);
7421
Kalle Valo5e3dd152013-06-12 20:52:10 +03007422 ar->hw->wiphy->interface_modes =
7423 BIT(NL80211_IFTYPE_STATION) |
Bob Copelandb6c7baf2015-09-09 12:47:36 -04007424 BIT(NL80211_IFTYPE_AP) |
7425 BIT(NL80211_IFTYPE_MESH_POINT);
Bartosz Markowskid3541812013-12-10 16:20:40 +01007426
Rajkumar Manoharan166de3f2015-10-27 17:51:11 +05307427 ar->hw->wiphy->available_antennas_rx = ar->cfg_rx_chainmask;
7428 ar->hw->wiphy->available_antennas_tx = ar->cfg_tx_chainmask;
Ben Greear46acf7b2014-05-16 17:15:38 +03007429
Bartosz Markowskid3541812013-12-10 16:20:40 +01007430 if (!test_bit(ATH10K_FW_FEATURE_NO_P2P, ar->fw_features))
7431 ar->hw->wiphy->interface_modes |=
Michal Kazior75d2bd42014-12-12 12:41:39 +01007432 BIT(NL80211_IFTYPE_P2P_DEVICE) |
Bartosz Markowskid3541812013-12-10 16:20:40 +01007433 BIT(NL80211_IFTYPE_P2P_CLIENT) |
7434 BIT(NL80211_IFTYPE_P2P_GO);
Kalle Valo5e3dd152013-06-12 20:52:10 +03007435
Johannes Berg30686bf2015-06-02 21:39:54 +02007436 ieee80211_hw_set(ar->hw, SIGNAL_DBM);
7437 ieee80211_hw_set(ar->hw, SUPPORTS_PS);
7438 ieee80211_hw_set(ar->hw, SUPPORTS_DYNAMIC_PS);
7439 ieee80211_hw_set(ar->hw, MFP_CAPABLE);
7440 ieee80211_hw_set(ar->hw, REPORTS_TX_ACK_STATUS);
7441 ieee80211_hw_set(ar->hw, HAS_RATE_CONTROL);
7442 ieee80211_hw_set(ar->hw, AP_LINK_PS);
7443 ieee80211_hw_set(ar->hw, SPECTRUM_MGMT);
Johannes Berg30686bf2015-06-02 21:39:54 +02007444 ieee80211_hw_set(ar->hw, SUPPORT_FAST_XMIT);
7445 ieee80211_hw_set(ar->hw, CONNECTION_MONITOR);
7446 ieee80211_hw_set(ar->hw, SUPPORTS_PER_STA_GTK);
7447 ieee80211_hw_set(ar->hw, WANT_MONITOR_VIF);
7448 ieee80211_hw_set(ar->hw, CHANCTX_STA_CSA);
7449 ieee80211_hw_set(ar->hw, QUEUE_CONTROL);
Kalle Valo5e3dd152013-06-12 20:52:10 +03007450
David Liuccec9032015-07-24 20:25:32 +03007451 if (!test_bit(ATH10K_FLAG_RAW_MODE, &ar->dev_flags))
7452 ieee80211_hw_set(ar->hw, SW_CRYPTO_CONTROL);
7453
Eliad Peller0d8614b2014-09-10 14:07:36 +03007454 ar->hw->wiphy->features |= NL80211_FEATURE_STATIC_SMPS;
Janusz Dziedzic0cd9bc12015-04-10 13:23:23 +00007455 ar->hw->wiphy->flags |= WIPHY_FLAG_IBSS_RSN;
Eliad Peller0d8614b2014-09-10 14:07:36 +03007456
Kalle Valo5e3dd152013-06-12 20:52:10 +03007457 if (ar->ht_cap_info & WMI_HT_CAP_DYNAMIC_SMPS)
Eliad Peller0d8614b2014-09-10 14:07:36 +03007458 ar->hw->wiphy->features |= NL80211_FEATURE_DYNAMIC_SMPS;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007459
7460 if (ar->ht_cap_info & WMI_HT_CAP_ENABLED) {
Johannes Berg30686bf2015-06-02 21:39:54 +02007461 ieee80211_hw_set(ar->hw, AMPDU_AGGREGATION);
7462 ieee80211_hw_set(ar->hw, TX_AMPDU_SETUP_IN_HW);
Kalle Valo5e3dd152013-06-12 20:52:10 +03007463 }
7464
7465 ar->hw->wiphy->max_scan_ssids = WLAN_SCAN_PARAMS_MAX_SSID;
7466 ar->hw->wiphy->max_scan_ie_len = WLAN_SCAN_PARAMS_MAX_IE_LEN;
7467
7468 ar->hw->vif_data_size = sizeof(struct ath10k_vif);
Michal Kazior9797feb2014-02-14 14:49:48 +01007469 ar->hw->sta_data_size = sizeof(struct ath10k_sta);
Kalle Valo5e3dd152013-06-12 20:52:10 +03007470
Kalle Valo5e3dd152013-06-12 20:52:10 +03007471 ar->hw->max_listen_interval = ATH10K_MAX_HW_LISTEN_INTERVAL;
7472
Michal Kaziorfbb8f1b2015-01-13 16:30:12 +02007473 if (test_bit(WMI_SERVICE_BEACON_OFFLOAD, ar->wmi.svc_map)) {
7474 ar->hw->wiphy->flags |= WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD;
7475
7476 /* Firmware delivers WPS/P2P Probe Requests frames to driver so
7477 * that userspace (e.g. wpa_supplicant/hostapd) can generate
7478 * correct Probe Responses. This is more of a hack advert..
7479 */
7480 ar->hw->wiphy->probe_resp_offload |=
7481 NL80211_PROBE_RESP_OFFLOAD_SUPPORT_WPS |
7482 NL80211_PROBE_RESP_OFFLOAD_SUPPORT_WPS2 |
7483 NL80211_PROBE_RESP_OFFLOAD_SUPPORT_P2P;
7484 }
7485
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03007486 if (test_bit(WMI_SERVICE_TDLS, ar->wmi.svc_map))
7487 ar->hw->wiphy->flags |= WIPHY_FLAG_SUPPORTS_TDLS;
7488
Kalle Valo5e3dd152013-06-12 20:52:10 +03007489 ar->hw->wiphy->flags |= WIPHY_FLAG_HAS_REMAIN_ON_CHANNEL;
Michal Kaziorc2df44b2014-01-23 11:38:26 +01007490 ar->hw->wiphy->flags |= WIPHY_FLAG_HAS_CHANNEL_SWITCH;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007491 ar->hw->wiphy->max_remain_on_channel_duration = 5000;
7492
7493 ar->hw->wiphy->flags |= WIPHY_FLAG_AP_UAPSD;
Rajkumar Manoharan78157a12014-11-17 16:44:15 +02007494 ar->hw->wiphy->features |= NL80211_FEATURE_AP_MODE_CHAN_WIDTH_CHANGE;
7495
Janusz.Dziedzic@tieto.com37a0b392015-03-12 13:11:41 +01007496 ar->hw->wiphy->max_ap_assoc_sta = ar->max_num_stations;
7497
Janusz Dziedzic5fd3ac32015-03-23 17:32:53 +02007498 ret = ath10k_wow_init(ar);
7499 if (ret) {
7500 ath10k_warn(ar, "failed to init wow: %d\n", ret);
7501 goto err_free;
7502 }
7503
Janusz Dziedzicc7025342015-06-15 14:46:41 +03007504 wiphy_ext_feature_set(ar->hw->wiphy, NL80211_EXT_FEATURE_VHT_IBSS);
7505
Kalle Valo5e3dd152013-06-12 20:52:10 +03007506 /*
7507 * on LL hardware queues are managed entirely by the FW
7508 * so we only advertise to mac we can do the queues thing
7509 */
Michal Kazior96d828d2015-03-31 10:26:23 +00007510 ar->hw->queues = IEEE80211_MAX_QUEUES;
7511
7512 /* vdev_ids are used as hw queue numbers. Make sure offchan tx queue is
7513 * something that vdev_ids can't reach so that we don't stop the queue
7514 * accidentally.
7515 */
7516 ar->hw->offchannel_tx_hw_queue = IEEE80211_MAX_QUEUES - 1;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007517
Kalle Valo5cc7caf2014-12-17 12:20:54 +02007518 switch (ar->wmi.op_version) {
7519 case ATH10K_FW_WMI_OP_VERSION_MAIN:
Bartosz Markowskif2595092013-12-10 16:20:39 +01007520 ar->hw->wiphy->iface_combinations = ath10k_if_comb;
7521 ar->hw->wiphy->n_iface_combinations =
7522 ARRAY_SIZE(ath10k_if_comb);
Michal Kaziorcf850d12014-07-24 20:07:00 +03007523 ar->hw->wiphy->interface_modes |= BIT(NL80211_IFTYPE_ADHOC);
Kalle Valo5cc7caf2014-12-17 12:20:54 +02007524 break;
Michal Kaziorcf327842015-03-31 10:26:25 +00007525 case ATH10K_FW_WMI_OP_VERSION_TLV:
7526 if (test_bit(WMI_SERVICE_ADAPTIVE_OCS, ar->wmi.svc_map)) {
7527 ar->hw->wiphy->iface_combinations =
7528 ath10k_tlv_qcs_if_comb;
7529 ar->hw->wiphy->n_iface_combinations =
7530 ARRAY_SIZE(ath10k_tlv_qcs_if_comb);
7531 } else {
7532 ar->hw->wiphy->iface_combinations = ath10k_tlv_if_comb;
7533 ar->hw->wiphy->n_iface_combinations =
7534 ARRAY_SIZE(ath10k_tlv_if_comb);
7535 }
7536 ar->hw->wiphy->interface_modes |= BIT(NL80211_IFTYPE_ADHOC);
7537 break;
Kalle Valo5cc7caf2014-12-17 12:20:54 +02007538 case ATH10K_FW_WMI_OP_VERSION_10_1:
7539 case ATH10K_FW_WMI_OP_VERSION_10_2:
Rajkumar Manoharan4a16fbe2014-12-17 12:21:12 +02007540 case ATH10K_FW_WMI_OP_VERSION_10_2_4:
Kalle Valo5cc7caf2014-12-17 12:20:54 +02007541 ar->hw->wiphy->iface_combinations = ath10k_10x_if_comb;
7542 ar->hw->wiphy->n_iface_combinations =
7543 ARRAY_SIZE(ath10k_10x_if_comb);
7544 break;
Raja Mani9bd21322015-06-22 20:10:09 +05307545 case ATH10K_FW_WMI_OP_VERSION_10_4:
Raja Manicf36fef2015-06-22 20:22:25 +05307546 ar->hw->wiphy->iface_combinations = ath10k_10_4_if_comb;
7547 ar->hw->wiphy->n_iface_combinations =
7548 ARRAY_SIZE(ath10k_10_4_if_comb);
Raja Mani9bd21322015-06-22 20:10:09 +05307549 break;
Kalle Valo5cc7caf2014-12-17 12:20:54 +02007550 case ATH10K_FW_WMI_OP_VERSION_UNSET:
7551 case ATH10K_FW_WMI_OP_VERSION_MAX:
7552 WARN_ON(1);
7553 ret = -EINVAL;
7554 goto err_free;
Bartosz Markowskif2595092013-12-10 16:20:39 +01007555 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03007556
David Liuccec9032015-07-24 20:25:32 +03007557 if (!test_bit(ATH10K_FLAG_RAW_MODE, &ar->dev_flags))
7558 ar->hw->netdev_features = NETIF_F_HW_CSUM;
Michal Kazior7c199992013-07-31 10:47:57 +02007559
Janusz Dziedzic9702c682013-11-20 09:59:41 +02007560 if (config_enabled(CONFIG_ATH10K_DFS_CERTIFIED)) {
7561 /* Init ath dfs pattern detector */
7562 ar->ath_common.debug_mask = ATH_DBG_DFS;
7563 ar->dfs_detector = dfs_pattern_detector_init(&ar->ath_common,
7564 NL80211_DFS_UNSET);
7565
7566 if (!ar->dfs_detector)
Michal Kazior7aa7a722014-08-25 12:09:38 +02007567 ath10k_warn(ar, "failed to initialise DFS pattern detector\n");
Janusz Dziedzic9702c682013-11-20 09:59:41 +02007568 }
7569
Kalle Valo5e3dd152013-06-12 20:52:10 +03007570 ret = ath_regd_init(&ar->ath_common.regulatory, ar->hw->wiphy,
7571 ath10k_reg_notifier);
7572 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02007573 ath10k_err(ar, "failed to initialise regulatory: %i\n", ret);
Jeff Johnson0e339442015-10-08 09:15:53 -07007574 goto err_dfs_detector_exit;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007575 }
7576
Johannes Berg3cb10942015-01-22 21:38:45 +01007577 ar->hw->wiphy->cipher_suites = cipher_suites;
7578 ar->hw->wiphy->n_cipher_suites = ARRAY_SIZE(cipher_suites);
7579
Kalle Valo5e3dd152013-06-12 20:52:10 +03007580 ret = ieee80211_register_hw(ar->hw);
7581 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02007582 ath10k_err(ar, "failed to register ieee80211: %d\n", ret);
Jeff Johnson0e339442015-10-08 09:15:53 -07007583 goto err_dfs_detector_exit;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007584 }
7585
7586 if (!ath_is_world_regd(&ar->ath_common.regulatory)) {
7587 ret = regulatory_hint(ar->hw->wiphy,
7588 ar->ath_common.regulatory.alpha2);
7589 if (ret)
Michal Kaziord6015b22013-07-22 14:13:30 +02007590 goto err_unregister;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007591 }
7592
7593 return 0;
Michal Kaziord6015b22013-07-22 14:13:30 +02007594
7595err_unregister:
Kalle Valo5e3dd152013-06-12 20:52:10 +03007596 ieee80211_unregister_hw(ar->hw);
Jeff Johnson0e339442015-10-08 09:15:53 -07007597
7598err_dfs_detector_exit:
7599 if (config_enabled(CONFIG_ATH10K_DFS_CERTIFIED) && ar->dfs_detector)
7600 ar->dfs_detector->exit(ar->dfs_detector);
7601
Michal Kaziord6015b22013-07-22 14:13:30 +02007602err_free:
7603 kfree(ar->mac.sbands[IEEE80211_BAND_2GHZ].channels);
7604 kfree(ar->mac.sbands[IEEE80211_BAND_5GHZ].channels);
7605
Jeff Johnson0e339442015-10-08 09:15:53 -07007606 SET_IEEE80211_DEV(ar->hw, NULL);
Kalle Valo5e3dd152013-06-12 20:52:10 +03007607 return ret;
7608}
7609
7610void ath10k_mac_unregister(struct ath10k *ar)
7611{
7612 ieee80211_unregister_hw(ar->hw);
7613
Janusz Dziedzic9702c682013-11-20 09:59:41 +02007614 if (config_enabled(CONFIG_ATH10K_DFS_CERTIFIED) && ar->dfs_detector)
7615 ar->dfs_detector->exit(ar->dfs_detector);
7616
Kalle Valo5e3dd152013-06-12 20:52:10 +03007617 kfree(ar->mac.sbands[IEEE80211_BAND_2GHZ].channels);
7618 kfree(ar->mac.sbands[IEEE80211_BAND_5GHZ].channels);
7619
7620 SET_IEEE80211_DEV(ar->hw, NULL);
7621}