blob: 74a42e3465e41d53f7df15a4fcbb51a63fe9bbd6 [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
Michal Kazior29946872016-03-06 16:14:34 +02003623static void ath10k_mac_txq_init(struct ieee80211_txq *txq)
3624{
3625 struct ath10k_txq *artxq = (void *)txq->drv_priv;
3626
3627 if (!txq)
3628 return;
3629
3630 INIT_LIST_HEAD(&artxq->list);
3631}
3632
3633static void ath10k_mac_txq_unref(struct ath10k *ar, struct ieee80211_txq *txq)
3634{
3635 struct ath10k_txq *artxq = (void *)txq->drv_priv;
3636
3637 if (!txq)
3638 return;
3639
3640 spin_lock_bh(&ar->txqs_lock);
3641 if (!list_empty(&artxq->list))
3642 list_del_init(&artxq->list);
3643 spin_unlock_bh(&ar->txqs_lock);
3644}
3645
3646static bool ath10k_mac_tx_can_push(struct ieee80211_hw *hw,
3647 struct ieee80211_txq *txq)
3648{
3649 return 1; /* TBD */
3650}
3651
3652static int ath10k_mac_tx_push_txq(struct ieee80211_hw *hw,
3653 struct ieee80211_txq *txq)
3654{
3655 const bool is_mgmt = false;
3656 const bool is_presp = false;
3657 struct ath10k *ar = hw->priv;
3658 struct ath10k_htt *htt = &ar->htt;
3659 struct ieee80211_vif *vif = txq->vif;
3660 struct ieee80211_sta *sta = txq->sta;
3661 enum ath10k_hw_txrx_mode txmode;
3662 enum ath10k_mac_tx_path txpath;
3663 struct sk_buff *skb;
3664 int ret;
3665
3666 spin_lock_bh(&ar->htt.tx_lock);
3667 ret = ath10k_htt_tx_inc_pending(htt, is_mgmt, is_presp);
3668 spin_unlock_bh(&ar->htt.tx_lock);
3669
3670 if (ret)
3671 return ret;
3672
3673 skb = ieee80211_tx_dequeue(hw, txq);
3674 if (!skb) {
3675 spin_lock_bh(&ar->htt.tx_lock);
3676 ath10k_htt_tx_dec_pending(htt, is_mgmt);
3677 spin_unlock_bh(&ar->htt.tx_lock);
3678
3679 return -ENOENT;
3680 }
3681
3682 ath10k_mac_tx_h_fill_cb(ar, vif, skb);
3683
3684 txmode = ath10k_mac_tx_h_get_txmode(ar, vif, sta, skb);
3685 txpath = ath10k_mac_tx_h_get_txpath(ar, skb, txmode);
3686
3687 ret = ath10k_mac_tx(ar, vif, sta, txmode, txpath, skb);
3688 if (unlikely(ret)) {
3689 ath10k_warn(ar, "failed to push frame: %d\n", ret);
3690
3691 spin_lock_bh(&ar->htt.tx_lock);
3692 ath10k_htt_tx_dec_pending(htt, is_mgmt);
3693 spin_unlock_bh(&ar->htt.tx_lock);
3694
3695 return ret;
3696 }
3697
3698 return 0;
3699}
3700
3701void ath10k_mac_tx_push_pending(struct ath10k *ar)
3702{
3703 struct ieee80211_hw *hw = ar->hw;
3704 struct ieee80211_txq *txq;
3705 struct ath10k_txq *artxq;
3706 struct ath10k_txq *last;
3707 int ret;
3708 int max;
3709
3710 spin_lock_bh(&ar->txqs_lock);
3711 rcu_read_lock();
3712
3713 last = list_last_entry(&ar->txqs, struct ath10k_txq, list);
3714 while (!list_empty(&ar->txqs)) {
3715 artxq = list_first_entry(&ar->txqs, struct ath10k_txq, list);
3716 txq = container_of((void *)artxq, struct ieee80211_txq,
3717 drv_priv);
3718
3719 /* Prevent aggressive sta/tid taking over tx queue */
3720 max = 16;
3721 while (max--) {
3722 ret = ath10k_mac_tx_push_txq(hw, txq);
3723 if (ret < 0)
3724 break;
3725 }
3726
3727 list_del_init(&artxq->list);
3728
3729 if (artxq == last || (ret < 0 && ret != -ENOENT)) {
3730 if (ret != -ENOENT)
3731 list_add_tail(&artxq->list, &ar->txqs);
3732 break;
3733 }
3734 }
3735
3736 rcu_read_unlock();
3737 spin_unlock_bh(&ar->txqs_lock);
3738}
3739
Kalle Valo5e3dd152013-06-12 20:52:10 +03003740/************/
3741/* Scanning */
3742/************/
3743
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003744void __ath10k_scan_finish(struct ath10k *ar)
Kalle Valo5e3dd152013-06-12 20:52:10 +03003745{
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003746 lockdep_assert_held(&ar->data_lock);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003747
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003748 switch (ar->scan.state) {
3749 case ATH10K_SCAN_IDLE:
3750 break;
3751 case ATH10K_SCAN_RUNNING:
Michal Kazior7305d3e2014-11-24 14:58:33 +01003752 case ATH10K_SCAN_ABORTING:
3753 if (!ar->scan.is_roc)
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003754 ieee80211_scan_completed(ar->hw,
3755 (ar->scan.state ==
3756 ATH10K_SCAN_ABORTING));
Michal Kaziord710e752015-07-09 13:08:36 +02003757 else if (ar->scan.roc_notify)
3758 ieee80211_remain_on_channel_expired(ar->hw);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003759 /* fall through */
3760 case ATH10K_SCAN_STARTING:
3761 ar->scan.state = ATH10K_SCAN_IDLE;
3762 ar->scan_channel = NULL;
Michal Kaziorbd877442015-11-18 06:59:19 +01003763 ar->scan.roc_freq = 0;
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003764 ath10k_offchan_tx_purge(ar);
3765 cancel_delayed_work(&ar->scan.timeout);
3766 complete_all(&ar->scan.completed);
3767 break;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003768 }
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003769}
Kalle Valo5e3dd152013-06-12 20:52:10 +03003770
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003771void ath10k_scan_finish(struct ath10k *ar)
3772{
3773 spin_lock_bh(&ar->data_lock);
3774 __ath10k_scan_finish(ar);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003775 spin_unlock_bh(&ar->data_lock);
3776}
3777
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003778static int ath10k_scan_stop(struct ath10k *ar)
Kalle Valo5e3dd152013-06-12 20:52:10 +03003779{
3780 struct wmi_stop_scan_arg arg = {
3781 .req_id = 1, /* FIXME */
3782 .req_type = WMI_SCAN_STOP_ONE,
3783 .u.scan_id = ATH10K_SCAN_ID,
3784 };
3785 int ret;
3786
3787 lockdep_assert_held(&ar->conf_mutex);
3788
Kalle Valo5e3dd152013-06-12 20:52:10 +03003789 ret = ath10k_wmi_stop_scan(ar, &arg);
3790 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003791 ath10k_warn(ar, "failed to stop wmi scan: %d\n", ret);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003792 goto out;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003793 }
3794
Kalle Valo5e3dd152013-06-12 20:52:10 +03003795 ret = wait_for_completion_timeout(&ar->scan.completed, 3*HZ);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003796 if (ret == 0) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003797 ath10k_warn(ar, "failed to receive scan abortion completion: timed out\n");
Kalle Valo5e3dd152013-06-12 20:52:10 +03003798 ret = -ETIMEDOUT;
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003799 } else if (ret > 0) {
3800 ret = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003801 }
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003802
3803out:
3804 /* Scan state should be updated upon scan completion but in case
3805 * firmware fails to deliver the event (for whatever reason) it is
3806 * desired to clean up scan state anyway. Firmware may have just
3807 * dropped the scan completion event delivery due to transport pipe
3808 * being overflown with data and/or it can recover on its own before
3809 * next scan request is submitted.
3810 */
3811 spin_lock_bh(&ar->data_lock);
3812 if (ar->scan.state != ATH10K_SCAN_IDLE)
3813 __ath10k_scan_finish(ar);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003814 spin_unlock_bh(&ar->data_lock);
3815
3816 return ret;
3817}
3818
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003819static void ath10k_scan_abort(struct ath10k *ar)
3820{
3821 int ret;
3822
3823 lockdep_assert_held(&ar->conf_mutex);
3824
3825 spin_lock_bh(&ar->data_lock);
3826
3827 switch (ar->scan.state) {
3828 case ATH10K_SCAN_IDLE:
3829 /* This can happen if timeout worker kicked in and called
3830 * abortion while scan completion was being processed.
3831 */
3832 break;
3833 case ATH10K_SCAN_STARTING:
3834 case ATH10K_SCAN_ABORTING:
Michal Kazior7aa7a722014-08-25 12:09:38 +02003835 ath10k_warn(ar, "refusing scan abortion due to invalid scan state: %s (%d)\n",
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003836 ath10k_scan_state_str(ar->scan.state),
3837 ar->scan.state);
3838 break;
3839 case ATH10K_SCAN_RUNNING:
3840 ar->scan.state = ATH10K_SCAN_ABORTING;
3841 spin_unlock_bh(&ar->data_lock);
3842
3843 ret = ath10k_scan_stop(ar);
3844 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003845 ath10k_warn(ar, "failed to abort scan: %d\n", ret);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003846
3847 spin_lock_bh(&ar->data_lock);
3848 break;
3849 }
3850
3851 spin_unlock_bh(&ar->data_lock);
3852}
3853
3854void ath10k_scan_timeout_work(struct work_struct *work)
3855{
3856 struct ath10k *ar = container_of(work, struct ath10k,
3857 scan.timeout.work);
3858
3859 mutex_lock(&ar->conf_mutex);
3860 ath10k_scan_abort(ar);
3861 mutex_unlock(&ar->conf_mutex);
3862}
3863
Kalle Valo5e3dd152013-06-12 20:52:10 +03003864static int ath10k_start_scan(struct ath10k *ar,
3865 const struct wmi_start_scan_arg *arg)
3866{
3867 int ret;
3868
3869 lockdep_assert_held(&ar->conf_mutex);
3870
3871 ret = ath10k_wmi_start_scan(ar, arg);
3872 if (ret)
3873 return ret;
3874
Kalle Valo5e3dd152013-06-12 20:52:10 +03003875 ret = wait_for_completion_timeout(&ar->scan.started, 1*HZ);
3876 if (ret == 0) {
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003877 ret = ath10k_scan_stop(ar);
3878 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003879 ath10k_warn(ar, "failed to stop scan: %d\n", ret);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003880
3881 return -ETIMEDOUT;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003882 }
3883
Ben Greear2f9eec02015-02-15 16:50:38 +02003884 /* If we failed to start the scan, return error code at
3885 * this point. This is probably due to some issue in the
3886 * firmware, but no need to wedge the driver due to that...
3887 */
3888 spin_lock_bh(&ar->data_lock);
3889 if (ar->scan.state == ATH10K_SCAN_IDLE) {
3890 spin_unlock_bh(&ar->data_lock);
3891 return -EINVAL;
3892 }
3893 spin_unlock_bh(&ar->data_lock);
3894
Kalle Valo5e3dd152013-06-12 20:52:10 +03003895 return 0;
3896}
3897
3898/**********************/
3899/* mac80211 callbacks */
3900/**********************/
3901
Michal Kaziorf2f6eca2016-03-01 11:32:46 +01003902static void ath10k_mac_op_tx(struct ieee80211_hw *hw,
3903 struct ieee80211_tx_control *control,
3904 struct sk_buff *skb)
Kalle Valo5e3dd152013-06-12 20:52:10 +03003905{
Kalle Valo5e3dd152013-06-12 20:52:10 +03003906 struct ath10k *ar = hw->priv;
Michal Kazior6421969f2016-03-06 16:14:25 +02003907 struct ath10k_htt *htt = &ar->htt;
Michal Kazior4b604552014-07-21 21:03:09 +03003908 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
3909 struct ieee80211_vif *vif = info->control.vif;
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03003910 struct ieee80211_sta *sta = control->sta;
Michal Kazior6421969f2016-03-06 16:14:25 +02003911 struct ieee80211_hdr *hdr = (void *)skb->data;
Michal Kazior8a933962015-11-18 06:59:17 +01003912 enum ath10k_hw_txrx_mode txmode;
Michal Kazior6421969f2016-03-06 16:14:25 +02003913 enum ath10k_mac_tx_path txpath;
3914 bool is_htt;
3915 bool is_mgmt;
3916 bool is_presp;
Michal Kaziorf2f6eca2016-03-01 11:32:46 +01003917 int ret;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003918
Michal Kaziorf2f6eca2016-03-01 11:32:46 +01003919 ath10k_mac_tx_h_fill_cb(ar, vif, skb);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003920
Michal Kazior8a933962015-11-18 06:59:17 +01003921 txmode = ath10k_mac_tx_h_get_txmode(ar, vif, sta, skb);
Michal Kazior6421969f2016-03-06 16:14:25 +02003922 txpath = ath10k_mac_tx_h_get_txpath(ar, skb, txmode);
3923 is_htt = (txpath == ATH10K_MAC_TX_HTT ||
3924 txpath == ATH10K_MAC_TX_HTT_MGMT);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003925
Michal Kazior6421969f2016-03-06 16:14:25 +02003926 if (is_htt) {
3927 spin_lock_bh(&ar->htt.tx_lock);
3928
3929 is_mgmt = ieee80211_is_mgmt(hdr->frame_control);
3930 is_presp = ieee80211_is_probe_resp(hdr->frame_control);
3931
3932 ret = ath10k_htt_tx_inc_pending(htt, is_mgmt, is_presp);
3933 if (ret) {
3934 ath10k_warn(ar, "failed to increase tx pending count: %d, dropping\n",
3935 ret);
3936 spin_unlock_bh(&ar->htt.tx_lock);
3937 ieee80211_free_txskb(ar->hw, skb);
3938 return;
3939 }
3940
3941 spin_unlock_bh(&ar->htt.tx_lock);
3942 }
3943
3944 ret = ath10k_mac_tx(ar, vif, sta, txmode, txpath, skb);
3945 if (ret) {
Michal Kaziorf2f6eca2016-03-01 11:32:46 +01003946 ath10k_warn(ar, "failed to transmit frame: %d\n", ret);
Michal Kazior6421969f2016-03-06 16:14:25 +02003947 if (is_htt) {
3948 spin_lock_bh(&ar->htt.tx_lock);
3949 ath10k_htt_tx_dec_pending(htt, is_mgmt);
3950 spin_unlock_bh(&ar->htt.tx_lock);
3951 }
3952 return;
3953 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03003954}
3955
Michal Kazior29946872016-03-06 16:14:34 +02003956static void ath10k_mac_op_wake_tx_queue(struct ieee80211_hw *hw,
3957 struct ieee80211_txq *txq)
3958{
3959 struct ath10k *ar = hw->priv;
3960 struct ath10k_txq *artxq = (void *)txq->drv_priv;
3961
3962 if (ath10k_mac_tx_can_push(hw, txq)) {
3963 spin_lock_bh(&ar->txqs_lock);
3964 if (list_empty(&artxq->list))
3965 list_add_tail(&artxq->list, &ar->txqs);
3966 spin_unlock_bh(&ar->txqs_lock);
3967
3968 tasklet_schedule(&ar->htt.txrx_compl_task);
3969 }
3970}
3971
Michal Kaziorbca7baf2014-05-26 12:46:03 +03003972/* Must not be called with conf_mutex held as workers can use that also. */
Michal Kazior7962b0d2014-10-28 10:34:38 +01003973void ath10k_drain_tx(struct ath10k *ar)
Michal Kaziorbca7baf2014-05-26 12:46:03 +03003974{
3975 /* make sure rcu-protected mac80211 tx path itself is drained */
3976 synchronize_net();
3977
3978 ath10k_offchan_tx_purge(ar);
3979 ath10k_mgmt_over_wmi_tx_purge(ar);
3980
3981 cancel_work_sync(&ar->offchan_tx_work);
3982 cancel_work_sync(&ar->wmi_mgmt_tx_work);
3983}
3984
Michal Kazioraffd3212013-07-16 09:54:35 +02003985void ath10k_halt(struct ath10k *ar)
Michal Kazior818bdd12013-07-16 09:38:57 +02003986{
Michal Kaziord9bc4b92014-04-23 19:30:06 +03003987 struct ath10k_vif *arvif;
3988
Michal Kazior818bdd12013-07-16 09:38:57 +02003989 lockdep_assert_held(&ar->conf_mutex);
3990
Michal Kazior19337472014-08-28 12:58:16 +02003991 clear_bit(ATH10K_CAC_RUNNING, &ar->dev_flags);
3992 ar->filter_flags = 0;
3993 ar->monitor = false;
Michal Kazior500ff9f2015-03-31 10:26:21 +00003994 ar->monitor_arvif = NULL;
Michal Kazior19337472014-08-28 12:58:16 +02003995
3996 if (ar->monitor_started)
Michal Kazior1bbc0972014-04-08 09:45:47 +03003997 ath10k_monitor_stop(ar);
Michal Kazior19337472014-08-28 12:58:16 +02003998
3999 ar->monitor_started = false;
Michal Kazior96d828d2015-03-31 10:26:23 +00004000 ar->tx_paused = 0;
Michal Kazior1bbc0972014-04-08 09:45:47 +03004001
Michal Kazior5c81c7f2014-08-05 14:54:44 +02004002 ath10k_scan_finish(ar);
Michal Kazior818bdd12013-07-16 09:38:57 +02004003 ath10k_peer_cleanup_all(ar);
4004 ath10k_core_stop(ar);
4005 ath10k_hif_power_down(ar);
4006
4007 spin_lock_bh(&ar->data_lock);
Michal Kazior64badcb2014-09-18 11:18:02 +03004008 list_for_each_entry(arvif, &ar->arvifs, list)
4009 ath10k_mac_vif_beacon_cleanup(arvif);
Michal Kazior818bdd12013-07-16 09:38:57 +02004010 spin_unlock_bh(&ar->data_lock);
4011}
4012
Ben Greear46acf7b2014-05-16 17:15:38 +03004013static int ath10k_get_antenna(struct ieee80211_hw *hw, u32 *tx_ant, u32 *rx_ant)
4014{
4015 struct ath10k *ar = hw->priv;
4016
4017 mutex_lock(&ar->conf_mutex);
4018
Rajkumar Manoharan166de3f2015-10-27 17:51:11 +05304019 *tx_ant = ar->cfg_tx_chainmask;
4020 *rx_ant = ar->cfg_rx_chainmask;
Ben Greear46acf7b2014-05-16 17:15:38 +03004021
4022 mutex_unlock(&ar->conf_mutex);
4023
4024 return 0;
4025}
4026
Ben Greear5572a952014-11-24 16:22:10 +02004027static void ath10k_check_chain_mask(struct ath10k *ar, u32 cm, const char *dbg)
4028{
4029 /* It is not clear that allowing gaps in chainmask
4030 * is helpful. Probably it will not do what user
4031 * is hoping for, so warn in that case.
4032 */
4033 if (cm == 15 || cm == 7 || cm == 3 || cm == 1 || cm == 0)
4034 return;
4035
4036 ath10k_warn(ar, "mac %s antenna chainmask may be invalid: 0x%x. Suggested values: 15, 7, 3, 1 or 0.\n",
4037 dbg, cm);
4038}
4039
Rajkumar Manoharanf58512f2015-10-27 17:51:13 +05304040static int ath10k_mac_get_vht_cap_bf_sts(struct ath10k *ar)
4041{
4042 int nsts = ar->vht_cap_info;
4043
4044 nsts &= IEEE80211_VHT_CAP_BEAMFORMEE_STS_MASK;
4045 nsts >>= IEEE80211_VHT_CAP_BEAMFORMEE_STS_SHIFT;
4046
4047 /* If firmware does not deliver to host number of space-time
4048 * streams supported, assume it support up to 4 BF STS and return
4049 * the value for VHT CAP: nsts-1)
4050 */
4051 if (nsts == 0)
4052 return 3;
4053
4054 return nsts;
4055}
4056
4057static int ath10k_mac_get_vht_cap_bf_sound_dim(struct ath10k *ar)
4058{
4059 int sound_dim = ar->vht_cap_info;
4060
4061 sound_dim &= IEEE80211_VHT_CAP_SOUNDING_DIMENSIONS_MASK;
4062 sound_dim >>= IEEE80211_VHT_CAP_SOUNDING_DIMENSIONS_SHIFT;
4063
4064 /* If the sounding dimension is not advertised by the firmware,
4065 * let's use a default value of 1
4066 */
4067 if (sound_dim == 0)
4068 return 1;
4069
4070 return sound_dim;
4071}
4072
4073static struct ieee80211_sta_vht_cap ath10k_create_vht_cap(struct ath10k *ar)
4074{
4075 struct ieee80211_sta_vht_cap vht_cap = {0};
4076 u16 mcs_map;
4077 u32 val;
4078 int i;
4079
4080 vht_cap.vht_supported = 1;
4081 vht_cap.cap = ar->vht_cap_info;
4082
4083 if (ar->vht_cap_info & (IEEE80211_VHT_CAP_SU_BEAMFORMEE_CAPABLE |
4084 IEEE80211_VHT_CAP_MU_BEAMFORMEE_CAPABLE)) {
4085 val = ath10k_mac_get_vht_cap_bf_sts(ar);
4086 val <<= IEEE80211_VHT_CAP_BEAMFORMEE_STS_SHIFT;
4087 val &= IEEE80211_VHT_CAP_BEAMFORMEE_STS_MASK;
4088
4089 vht_cap.cap |= val;
4090 }
4091
4092 if (ar->vht_cap_info & (IEEE80211_VHT_CAP_SU_BEAMFORMER_CAPABLE |
4093 IEEE80211_VHT_CAP_MU_BEAMFORMER_CAPABLE)) {
4094 val = ath10k_mac_get_vht_cap_bf_sound_dim(ar);
4095 val <<= IEEE80211_VHT_CAP_SOUNDING_DIMENSIONS_SHIFT;
4096 val &= IEEE80211_VHT_CAP_SOUNDING_DIMENSIONS_MASK;
4097
4098 vht_cap.cap |= val;
4099 }
4100
4101 mcs_map = 0;
4102 for (i = 0; i < 8; i++) {
4103 if ((i < ar->num_rf_chains) && (ar->cfg_tx_chainmask & BIT(i)))
4104 mcs_map |= IEEE80211_VHT_MCS_SUPPORT_0_9 << (i * 2);
4105 else
4106 mcs_map |= IEEE80211_VHT_MCS_NOT_SUPPORTED << (i * 2);
4107 }
4108
4109 vht_cap.vht_mcs.rx_mcs_map = cpu_to_le16(mcs_map);
4110 vht_cap.vht_mcs.tx_mcs_map = cpu_to_le16(mcs_map);
4111
4112 return vht_cap;
4113}
4114
4115static struct ieee80211_sta_ht_cap ath10k_get_ht_cap(struct ath10k *ar)
4116{
4117 int i;
4118 struct ieee80211_sta_ht_cap ht_cap = {0};
4119
4120 if (!(ar->ht_cap_info & WMI_HT_CAP_ENABLED))
4121 return ht_cap;
4122
4123 ht_cap.ht_supported = 1;
4124 ht_cap.ampdu_factor = IEEE80211_HT_MAX_AMPDU_64K;
4125 ht_cap.ampdu_density = IEEE80211_HT_MPDU_DENSITY_8;
4126 ht_cap.cap |= IEEE80211_HT_CAP_SUP_WIDTH_20_40;
4127 ht_cap.cap |= IEEE80211_HT_CAP_DSSSCCK40;
Peter Ohe33a99e2015-12-31 15:26:20 +02004128 ht_cap.cap |=
4129 WLAN_HT_CAP_SM_PS_DISABLED << IEEE80211_HT_CAP_SM_PS_SHIFT;
Rajkumar Manoharanf58512f2015-10-27 17:51:13 +05304130
4131 if (ar->ht_cap_info & WMI_HT_CAP_HT20_SGI)
4132 ht_cap.cap |= IEEE80211_HT_CAP_SGI_20;
4133
4134 if (ar->ht_cap_info & WMI_HT_CAP_HT40_SGI)
4135 ht_cap.cap |= IEEE80211_HT_CAP_SGI_40;
4136
4137 if (ar->ht_cap_info & WMI_HT_CAP_DYNAMIC_SMPS) {
4138 u32 smps;
4139
4140 smps = WLAN_HT_CAP_SM_PS_DYNAMIC;
4141 smps <<= IEEE80211_HT_CAP_SM_PS_SHIFT;
4142
4143 ht_cap.cap |= smps;
4144 }
4145
4146 if (ar->ht_cap_info & WMI_HT_CAP_TX_STBC)
4147 ht_cap.cap |= IEEE80211_HT_CAP_TX_STBC;
4148
4149 if (ar->ht_cap_info & WMI_HT_CAP_RX_STBC) {
4150 u32 stbc;
4151
4152 stbc = ar->ht_cap_info;
4153 stbc &= WMI_HT_CAP_RX_STBC;
4154 stbc >>= WMI_HT_CAP_RX_STBC_MASK_SHIFT;
4155 stbc <<= IEEE80211_HT_CAP_RX_STBC_SHIFT;
4156 stbc &= IEEE80211_HT_CAP_RX_STBC;
4157
4158 ht_cap.cap |= stbc;
4159 }
4160
4161 if (ar->ht_cap_info & WMI_HT_CAP_LDPC)
4162 ht_cap.cap |= IEEE80211_HT_CAP_LDPC_CODING;
4163
4164 if (ar->ht_cap_info & WMI_HT_CAP_L_SIG_TXOP_PROT)
4165 ht_cap.cap |= IEEE80211_HT_CAP_LSIG_TXOP_PROT;
4166
4167 /* max AMSDU is implicitly taken from vht_cap_info */
4168 if (ar->vht_cap_info & WMI_VHT_CAP_MAX_MPDU_LEN_MASK)
4169 ht_cap.cap |= IEEE80211_HT_CAP_MAX_AMSDU;
4170
4171 for (i = 0; i < ar->num_rf_chains; i++) {
4172 if (ar->cfg_rx_chainmask & BIT(i))
4173 ht_cap.mcs.rx_mask[i] = 0xFF;
4174 }
4175
4176 ht_cap.mcs.tx_params |= IEEE80211_HT_MCS_TX_DEFINED;
4177
4178 return ht_cap;
4179}
4180
Rajkumar Manoharan5036fe02015-10-27 17:51:14 +05304181static void ath10k_mac_setup_ht_vht_cap(struct ath10k *ar)
4182{
4183 struct ieee80211_supported_band *band;
4184 struct ieee80211_sta_vht_cap vht_cap;
4185 struct ieee80211_sta_ht_cap ht_cap;
4186
4187 ht_cap = ath10k_get_ht_cap(ar);
4188 vht_cap = ath10k_create_vht_cap(ar);
4189
4190 if (ar->phy_capability & WHAL_WLAN_11G_CAPABILITY) {
4191 band = &ar->mac.sbands[IEEE80211_BAND_2GHZ];
4192 band->ht_cap = ht_cap;
4193
4194 /* Enable the VHT support at 2.4 GHz */
4195 band->vht_cap = vht_cap;
4196 }
4197 if (ar->phy_capability & WHAL_WLAN_11A_CAPABILITY) {
4198 band = &ar->mac.sbands[IEEE80211_BAND_5GHZ];
4199 band->ht_cap = ht_cap;
4200 band->vht_cap = vht_cap;
4201 }
4202}
4203
Ben Greear46acf7b2014-05-16 17:15:38 +03004204static int __ath10k_set_antenna(struct ath10k *ar, u32 tx_ant, u32 rx_ant)
4205{
4206 int ret;
4207
4208 lockdep_assert_held(&ar->conf_mutex);
4209
Ben Greear5572a952014-11-24 16:22:10 +02004210 ath10k_check_chain_mask(ar, tx_ant, "tx");
4211 ath10k_check_chain_mask(ar, rx_ant, "rx");
4212
Ben Greear46acf7b2014-05-16 17:15:38 +03004213 ar->cfg_tx_chainmask = tx_ant;
4214 ar->cfg_rx_chainmask = rx_ant;
4215
4216 if ((ar->state != ATH10K_STATE_ON) &&
4217 (ar->state != ATH10K_STATE_RESTARTED))
4218 return 0;
4219
4220 ret = ath10k_wmi_pdev_set_param(ar, ar->wmi.pdev_param->tx_chain_mask,
4221 tx_ant);
4222 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004223 ath10k_warn(ar, "failed to set tx-chainmask: %d, req 0x%x\n",
Ben Greear46acf7b2014-05-16 17:15:38 +03004224 ret, tx_ant);
4225 return ret;
4226 }
4227
4228 ret = ath10k_wmi_pdev_set_param(ar, ar->wmi.pdev_param->rx_chain_mask,
4229 rx_ant);
4230 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004231 ath10k_warn(ar, "failed to set rx-chainmask: %d, req 0x%x\n",
Ben Greear46acf7b2014-05-16 17:15:38 +03004232 ret, rx_ant);
4233 return ret;
4234 }
4235
Rajkumar Manoharan5036fe02015-10-27 17:51:14 +05304236 /* Reload HT/VHT capability */
4237 ath10k_mac_setup_ht_vht_cap(ar);
4238
Ben Greear46acf7b2014-05-16 17:15:38 +03004239 return 0;
4240}
4241
4242static int ath10k_set_antenna(struct ieee80211_hw *hw, u32 tx_ant, u32 rx_ant)
4243{
4244 struct ath10k *ar = hw->priv;
4245 int ret;
4246
4247 mutex_lock(&ar->conf_mutex);
4248 ret = __ath10k_set_antenna(ar, tx_ant, rx_ant);
4249 mutex_unlock(&ar->conf_mutex);
4250 return ret;
4251}
4252
Kalle Valo5e3dd152013-06-12 20:52:10 +03004253static int ath10k_start(struct ieee80211_hw *hw)
4254{
4255 struct ath10k *ar = hw->priv;
Mohammed Shafi Shajakhan1fe374f2016-01-13 21:16:30 +05304256 u32 param;
Michal Kazior818bdd12013-07-16 09:38:57 +02004257 int ret = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004258
Michal Kaziorbca7baf2014-05-26 12:46:03 +03004259 /*
4260 * This makes sense only when restarting hw. It is harmless to call
4261 * uncoditionally. This is necessary to make sure no HTT/WMI tx
4262 * commands will be submitted while restarting.
4263 */
4264 ath10k_drain_tx(ar);
4265
Michal Kazior548db542013-07-05 16:15:15 +03004266 mutex_lock(&ar->conf_mutex);
4267
Michal Kaziorc5058f52014-05-26 12:46:03 +03004268 switch (ar->state) {
4269 case ATH10K_STATE_OFF:
4270 ar->state = ATH10K_STATE_ON;
4271 break;
4272 case ATH10K_STATE_RESTARTING:
4273 ath10k_halt(ar);
4274 ar->state = ATH10K_STATE_RESTARTED;
4275 break;
4276 case ATH10K_STATE_ON:
4277 case ATH10K_STATE_RESTARTED:
4278 case ATH10K_STATE_WEDGED:
4279 WARN_ON(1);
Michal Kazior818bdd12013-07-16 09:38:57 +02004280 ret = -EINVAL;
Michal Kaziorae254432014-05-26 12:46:02 +03004281 goto err;
Kalle Valo43d2a302014-09-10 18:23:30 +03004282 case ATH10K_STATE_UTF:
4283 ret = -EBUSY;
4284 goto err;
Michal Kazior818bdd12013-07-16 09:38:57 +02004285 }
4286
4287 ret = ath10k_hif_power_up(ar);
4288 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004289 ath10k_err(ar, "Could not init hif: %d\n", ret);
Michal Kaziorae254432014-05-26 12:46:02 +03004290 goto err_off;
Michal Kazior818bdd12013-07-16 09:38:57 +02004291 }
4292
Kalle Valo43d2a302014-09-10 18:23:30 +03004293 ret = ath10k_core_start(ar, ATH10K_FIRMWARE_MODE_NORMAL);
Michal Kazior818bdd12013-07-16 09:38:57 +02004294 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004295 ath10k_err(ar, "Could not init core: %d\n", ret);
Michal Kaziorae254432014-05-26 12:46:02 +03004296 goto err_power_down;
Michal Kazior818bdd12013-07-16 09:38:57 +02004297 }
4298
Mohammed Shafi Shajakhan1fe374f2016-01-13 21:16:30 +05304299 param = ar->wmi.pdev_param->pmf_qos;
4300 ret = ath10k_wmi_pdev_set_param(ar, param, 1);
Michal Kaziorae254432014-05-26 12:46:02 +03004301 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004302 ath10k_warn(ar, "failed to enable PMF QOS: %d\n", ret);
Michal Kaziorae254432014-05-26 12:46:02 +03004303 goto err_core_stop;
4304 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004305
Mohammed Shafi Shajakhan1fe374f2016-01-13 21:16:30 +05304306 param = ar->wmi.pdev_param->dynamic_bw;
4307 ret = ath10k_wmi_pdev_set_param(ar, param, 1);
Michal Kaziorae254432014-05-26 12:46:02 +03004308 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004309 ath10k_warn(ar, "failed to enable dynamic BW: %d\n", ret);
Michal Kaziorae254432014-05-26 12:46:02 +03004310 goto err_core_stop;
4311 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004312
Michal Kaziorcf327842015-03-31 10:26:25 +00004313 if (test_bit(WMI_SERVICE_ADAPTIVE_OCS, ar->wmi.svc_map)) {
4314 ret = ath10k_wmi_adaptive_qcs(ar, true);
4315 if (ret) {
4316 ath10k_warn(ar, "failed to enable adaptive qcs: %d\n",
4317 ret);
4318 goto err_core_stop;
4319 }
4320 }
4321
Janusz Dziedzic24ab13e2015-04-01 22:53:18 +03004322 if (test_bit(WMI_SERVICE_BURST, ar->wmi.svc_map)) {
Mohammed Shafi Shajakhan1fe374f2016-01-13 21:16:30 +05304323 param = ar->wmi.pdev_param->burst_enable;
4324 ret = ath10k_wmi_pdev_set_param(ar, param, 0);
Janusz Dziedzic24ab13e2015-04-01 22:53:18 +03004325 if (ret) {
4326 ath10k_warn(ar, "failed to disable burst: %d\n", ret);
4327 goto err_core_stop;
4328 }
4329 }
4330
Rajkumar Manoharan166de3f2015-10-27 17:51:11 +05304331 __ath10k_set_antenna(ar, ar->cfg_tx_chainmask, ar->cfg_rx_chainmask);
Ben Greear46acf7b2014-05-16 17:15:38 +03004332
Marek Puzyniakab6258e2014-01-29 15:03:31 +02004333 /*
4334 * By default FW set ARP frames ac to voice (6). In that case ARP
4335 * exchange is not working properly for UAPSD enabled AP. ARP requests
4336 * which arrives with access category 0 are processed by network stack
4337 * and send back with access category 0, but FW changes access category
4338 * to 6. Set ARP frames access category to best effort (0) solves
4339 * this problem.
4340 */
4341
Mohammed Shafi Shajakhan1fe374f2016-01-13 21:16:30 +05304342 param = ar->wmi.pdev_param->arp_ac_override;
4343 ret = ath10k_wmi_pdev_set_param(ar, param, 0);
Marek Puzyniakab6258e2014-01-29 15:03:31 +02004344 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004345 ath10k_warn(ar, "failed to set arp ac override parameter: %d\n",
Marek Puzyniakab6258e2014-01-29 15:03:31 +02004346 ret);
Michal Kaziorae254432014-05-26 12:46:02 +03004347 goto err_core_stop;
Marek Puzyniakab6258e2014-01-29 15:03:31 +02004348 }
4349
Maharaja62f77f02015-10-21 11:49:18 +03004350 if (test_bit(ATH10K_FW_FEATURE_SUPPORTS_ADAPTIVE_CCA,
4351 ar->fw_features)) {
4352 ret = ath10k_wmi_pdev_enable_adaptive_cca(ar, 1,
4353 WMI_CCA_DETECT_LEVEL_AUTO,
4354 WMI_CCA_DETECT_MARGIN_AUTO);
4355 if (ret) {
4356 ath10k_warn(ar, "failed to enable adaptive cca: %d\n",
4357 ret);
4358 goto err_core_stop;
4359 }
4360 }
4361
Mohammed Shafi Shajakhan1fe374f2016-01-13 21:16:30 +05304362 param = ar->wmi.pdev_param->ani_enable;
4363 ret = ath10k_wmi_pdev_set_param(ar, param, 1);
Ashok Raj Nagarajan575f1c32015-03-19 16:37:59 +05304364 if (ret) {
4365 ath10k_warn(ar, "failed to enable ani by default: %d\n",
4366 ret);
4367 goto err_core_stop;
4368 }
4369
Ashok Raj Nagarajanb3e71d72015-03-19 16:38:00 +05304370 ar->ani_enabled = true;
4371
Mohammed Shafi Shajakhan8351c052016-01-13 21:16:33 +05304372 if (test_bit(WMI_SERVICE_PEER_STATS, ar->wmi.svc_map)) {
4373 param = ar->wmi.pdev_param->peer_stats_update_period;
4374 ret = ath10k_wmi_pdev_set_param(ar, param,
4375 PEER_DEFAULT_STATS_UPDATE_PERIOD);
4376 if (ret) {
4377 ath10k_warn(ar,
4378 "failed to set peer stats period : %d\n",
4379 ret);
4380 goto err_core_stop;
4381 }
4382 }
4383
Michal Kaziord6500972014-04-08 09:56:09 +03004384 ar->num_started_vdevs = 0;
Michal Kaziorf7843d72013-07-16 09:38:52 +02004385 ath10k_regd_update(ar);
4386
Simon Wunderlich855aed12014-08-02 09:12:54 +03004387 ath10k_spectral_start(ar);
Rajkumar Manoharan8515b5c2015-03-15 20:36:22 +05304388 ath10k_thermal_set_throttling(ar);
Simon Wunderlich855aed12014-08-02 09:12:54 +03004389
Michal Kaziorae254432014-05-26 12:46:02 +03004390 mutex_unlock(&ar->conf_mutex);
4391 return 0;
4392
4393err_core_stop:
4394 ath10k_core_stop(ar);
4395
4396err_power_down:
4397 ath10k_hif_power_down(ar);
4398
4399err_off:
4400 ar->state = ATH10K_STATE_OFF;
4401
4402err:
Michal Kazior548db542013-07-05 16:15:15 +03004403 mutex_unlock(&ar->conf_mutex);
Michal Kaziorc60bdd82014-01-29 07:26:31 +01004404 return ret;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004405}
4406
4407static void ath10k_stop(struct ieee80211_hw *hw)
4408{
4409 struct ath10k *ar = hw->priv;
4410
Michal Kaziorbca7baf2014-05-26 12:46:03 +03004411 ath10k_drain_tx(ar);
4412
Michal Kazior548db542013-07-05 16:15:15 +03004413 mutex_lock(&ar->conf_mutex);
Michal Kaziorc5058f52014-05-26 12:46:03 +03004414 if (ar->state != ATH10K_STATE_OFF) {
Michal Kazior818bdd12013-07-16 09:38:57 +02004415 ath10k_halt(ar);
Michal Kaziorc5058f52014-05-26 12:46:03 +03004416 ar->state = ATH10K_STATE_OFF;
4417 }
Michal Kazior548db542013-07-05 16:15:15 +03004418 mutex_unlock(&ar->conf_mutex);
4419
Michal Kazior5c81c7f2014-08-05 14:54:44 +02004420 cancel_delayed_work_sync(&ar->scan.timeout);
Michal Kazioraffd3212013-07-16 09:54:35 +02004421 cancel_work_sync(&ar->restart_work);
4422}
4423
Michal Kaziorad088bf2013-10-16 15:44:46 +03004424static int ath10k_config_ps(struct ath10k *ar)
Michal Kazioraffd3212013-07-16 09:54:35 +02004425{
Michal Kaziorad088bf2013-10-16 15:44:46 +03004426 struct ath10k_vif *arvif;
4427 int ret = 0;
Michal Kazioraffd3212013-07-16 09:54:35 +02004428
4429 lockdep_assert_held(&ar->conf_mutex);
4430
Michal Kaziorad088bf2013-10-16 15:44:46 +03004431 list_for_each_entry(arvif, &ar->arvifs, list) {
4432 ret = ath10k_mac_vif_setup_ps(arvif);
4433 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004434 ath10k_warn(ar, "failed to setup powersave: %d\n", ret);
Michal Kaziorad088bf2013-10-16 15:44:46 +03004435 break;
4436 }
4437 }
Michal Kazioraffd3212013-07-16 09:54:35 +02004438
Michal Kaziorad088bf2013-10-16 15:44:46 +03004439 return ret;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004440}
4441
Michal Kazior7d9d5582014-10-21 10:40:15 +03004442static int ath10k_mac_txpower_setup(struct ath10k *ar, int txpower)
4443{
4444 int ret;
4445 u32 param;
4446
4447 lockdep_assert_held(&ar->conf_mutex);
4448
4449 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac txpower %d\n", txpower);
4450
4451 param = ar->wmi.pdev_param->txpower_limit2g;
4452 ret = ath10k_wmi_pdev_set_param(ar, param, txpower * 2);
4453 if (ret) {
4454 ath10k_warn(ar, "failed to set 2g txpower %d: %d\n",
4455 txpower, ret);
4456 return ret;
4457 }
4458
4459 param = ar->wmi.pdev_param->txpower_limit5g;
4460 ret = ath10k_wmi_pdev_set_param(ar, param, txpower * 2);
4461 if (ret) {
4462 ath10k_warn(ar, "failed to set 5g txpower %d: %d\n",
4463 txpower, ret);
4464 return ret;
4465 }
4466
4467 return 0;
4468}
4469
4470static int ath10k_mac_txpower_recalc(struct ath10k *ar)
4471{
4472 struct ath10k_vif *arvif;
4473 int ret, txpower = -1;
4474
4475 lockdep_assert_held(&ar->conf_mutex);
4476
4477 list_for_each_entry(arvif, &ar->arvifs, list) {
4478 WARN_ON(arvif->txpower < 0);
4479
4480 if (txpower == -1)
4481 txpower = arvif->txpower;
4482 else
4483 txpower = min(txpower, arvif->txpower);
4484 }
4485
4486 if (WARN_ON(txpower == -1))
4487 return -EINVAL;
4488
4489 ret = ath10k_mac_txpower_setup(ar, txpower);
4490 if (ret) {
4491 ath10k_warn(ar, "failed to setup tx power %d: %d\n",
4492 txpower, ret);
4493 return ret;
4494 }
4495
4496 return 0;
4497}
4498
Kalle Valo5e3dd152013-06-12 20:52:10 +03004499static int ath10k_config(struct ieee80211_hw *hw, u32 changed)
4500{
Kalle Valo5e3dd152013-06-12 20:52:10 +03004501 struct ath10k *ar = hw->priv;
4502 struct ieee80211_conf *conf = &hw->conf;
4503 int ret = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004504
4505 mutex_lock(&ar->conf_mutex);
4506
Michal Kazioraffd3212013-07-16 09:54:35 +02004507 if (changed & IEEE80211_CONF_CHANGE_PS)
4508 ath10k_config_ps(ar);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004509
4510 if (changed & IEEE80211_CONF_CHANGE_MONITOR) {
Michal Kazior19337472014-08-28 12:58:16 +02004511 ar->monitor = conf->flags & IEEE80211_CONF_MONITOR;
4512 ret = ath10k_monitor_recalc(ar);
4513 if (ret)
4514 ath10k_warn(ar, "failed to recalc monitor: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004515 }
4516
4517 mutex_unlock(&ar->conf_mutex);
4518 return ret;
4519}
4520
Ben Greear5572a952014-11-24 16:22:10 +02004521static u32 get_nss_from_chainmask(u16 chain_mask)
4522{
Rajkumar Manoharanf680f702015-11-03 11:51:33 +05304523 if ((chain_mask & 0xf) == 0xf)
Ben Greear5572a952014-11-24 16:22:10 +02004524 return 4;
4525 else if ((chain_mask & 0x7) == 0x7)
4526 return 3;
4527 else if ((chain_mask & 0x3) == 0x3)
4528 return 2;
4529 return 1;
4530}
4531
Vivek Natarajana48e2cc2015-08-04 10:45:12 +05304532static int ath10k_mac_set_txbf_conf(struct ath10k_vif *arvif)
4533{
4534 u32 value = 0;
4535 struct ath10k *ar = arvif->ar;
Bartosz Markowski707a0c82015-09-02 13:20:19 +02004536 int nsts;
Bartosz Markowski0c6d6f22015-09-02 13:20:20 +02004537 int sound_dim;
Vivek Natarajana48e2cc2015-08-04 10:45:12 +05304538
4539 if (ath10k_wmi_get_txbf_conf_scheme(ar) != WMI_TXBF_CONF_BEFORE_ASSOC)
4540 return 0;
4541
Bartosz Markowski707a0c82015-09-02 13:20:19 +02004542 nsts = ath10k_mac_get_vht_cap_bf_sts(ar);
Vivek Natarajana48e2cc2015-08-04 10:45:12 +05304543 if (ar->vht_cap_info & (IEEE80211_VHT_CAP_SU_BEAMFORMEE_CAPABLE |
4544 IEEE80211_VHT_CAP_MU_BEAMFORMEE_CAPABLE))
Bartosz Markowski707a0c82015-09-02 13:20:19 +02004545 value |= SM(nsts, WMI_TXBF_STS_CAP_OFFSET);
Vivek Natarajana48e2cc2015-08-04 10:45:12 +05304546
Bartosz Markowski0c6d6f22015-09-02 13:20:20 +02004547 sound_dim = ath10k_mac_get_vht_cap_bf_sound_dim(ar);
Vivek Natarajana48e2cc2015-08-04 10:45:12 +05304548 if (ar->vht_cap_info & (IEEE80211_VHT_CAP_SU_BEAMFORMER_CAPABLE |
4549 IEEE80211_VHT_CAP_MU_BEAMFORMER_CAPABLE))
Bartosz Markowski0c6d6f22015-09-02 13:20:20 +02004550 value |= SM(sound_dim, WMI_BF_SOUND_DIM_OFFSET);
Vivek Natarajana48e2cc2015-08-04 10:45:12 +05304551
4552 if (!value)
4553 return 0;
4554
4555 if (ar->vht_cap_info & IEEE80211_VHT_CAP_SU_BEAMFORMER_CAPABLE)
4556 value |= WMI_VDEV_PARAM_TXBF_SU_TX_BFER;
4557
4558 if (ar->vht_cap_info & IEEE80211_VHT_CAP_MU_BEAMFORMER_CAPABLE)
4559 value |= (WMI_VDEV_PARAM_TXBF_MU_TX_BFER |
4560 WMI_VDEV_PARAM_TXBF_SU_TX_BFER);
4561
4562 if (ar->vht_cap_info & IEEE80211_VHT_CAP_SU_BEAMFORMEE_CAPABLE)
4563 value |= WMI_VDEV_PARAM_TXBF_SU_TX_BFEE;
4564
4565 if (ar->vht_cap_info & IEEE80211_VHT_CAP_MU_BEAMFORMEE_CAPABLE)
4566 value |= (WMI_VDEV_PARAM_TXBF_MU_TX_BFEE |
4567 WMI_VDEV_PARAM_TXBF_SU_TX_BFEE);
4568
4569 return ath10k_wmi_vdev_set_param(ar, arvif->vdev_id,
4570 ar->wmi.vdev_param->txbf, value);
4571}
4572
Kalle Valo5e3dd152013-06-12 20:52:10 +03004573/*
4574 * TODO:
4575 * Figure out how to handle WMI_VDEV_SUBTYPE_P2P_DEVICE,
4576 * because we will send mgmt frames without CCK. This requirement
4577 * for P2P_FIND/GO_NEG should be handled by checking CCK flag
4578 * in the TX packet.
4579 */
4580static int ath10k_add_interface(struct ieee80211_hw *hw,
4581 struct ieee80211_vif *vif)
4582{
4583 struct ath10k *ar = hw->priv;
4584 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kaziorbb8f0c62016-03-06 16:14:27 +02004585 struct ath10k_peer *peer;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004586 enum wmi_sta_powersave_param param;
4587 int ret = 0;
Kalle Valo5a13e762014-01-20 11:01:46 +02004588 u32 value;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004589 int bit;
Michal Kazior96d828d2015-03-31 10:26:23 +00004590 int i;
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02004591 u32 vdev_param;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004592
Johannes Berg848955c2014-11-11 12:48:42 +01004593 vif->driver_flags |= IEEE80211_VIF_SUPPORTS_UAPSD;
4594
Kalle Valo5e3dd152013-06-12 20:52:10 +03004595 mutex_lock(&ar->conf_mutex);
4596
Michal Kazior0dbd09e2013-07-31 10:55:14 +02004597 memset(arvif, 0, sizeof(*arvif));
Michal Kazior29946872016-03-06 16:14:34 +02004598 ath10k_mac_txq_init(vif->txq);
Michal Kazior0dbd09e2013-07-31 10:55:14 +02004599
Kalle Valo5e3dd152013-06-12 20:52:10 +03004600 arvif->ar = ar;
4601 arvif->vif = vif;
4602
Ben Greeare63b33f2013-10-22 14:54:14 -07004603 INIT_LIST_HEAD(&arvif->list);
Michal Kazior81a9a172015-03-05 16:02:17 +02004604 INIT_WORK(&arvif->ap_csa_work, ath10k_mac_vif_ap_csa_work);
Michal Kaziorcc9904e2015-03-10 16:22:01 +02004605 INIT_DELAYED_WORK(&arvif->connection_loss_work,
4606 ath10k_mac_vif_sta_connection_loss_work);
Michal Kaziorcc4827b2013-10-16 15:44:45 +03004607
Michal Kazior45c9abc2015-04-21 20:42:58 +03004608 for (i = 0; i < ARRAY_SIZE(arvif->bitrate_mask.control); i++) {
4609 arvif->bitrate_mask.control[i].legacy = 0xffffffff;
4610 memset(arvif->bitrate_mask.control[i].ht_mcs, 0xff,
4611 sizeof(arvif->bitrate_mask.control[i].ht_mcs));
4612 memset(arvif->bitrate_mask.control[i].vht_mcs, 0xff,
4613 sizeof(arvif->bitrate_mask.control[i].vht_mcs));
4614 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004615
Michal Kaziore04cafb2015-08-05 12:15:24 +02004616 if (ar->num_peers >= ar->max_num_peers) {
4617 ath10k_warn(ar, "refusing vdev creation due to insufficient peer entry resources in firmware\n");
Michal Kazior503422d2015-08-19 13:08:53 +02004618 ret = -ENOBUFS;
4619 goto err;
Michal Kaziore04cafb2015-08-05 12:15:24 +02004620 }
4621
Ben Greeara9aefb32014-08-12 11:02:19 +03004622 if (ar->free_vdev_map == 0) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004623 ath10k_warn(ar, "Free vdev map is empty, no more interfaces allowed.\n");
Kalle Valo5e3dd152013-06-12 20:52:10 +03004624 ret = -EBUSY;
Michal Kazior9dad14a2013-10-16 15:44:45 +03004625 goto err;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004626 }
Ben Greear16c11172014-09-23 14:17:16 -07004627 bit = __ffs64(ar->free_vdev_map);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004628
Ben Greear16c11172014-09-23 14:17:16 -07004629 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac create vdev %i map %llx\n",
4630 bit, ar->free_vdev_map);
4631
4632 arvif->vdev_id = bit;
Peter Oh6e4de1a2016-01-28 13:54:10 -08004633 arvif->vdev_subtype =
4634 ath10k_wmi_get_vdev_subtype(ar, WMI_VDEV_SUBTYPE_NONE);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004635
Kalle Valo5e3dd152013-06-12 20:52:10 +03004636 switch (vif->type) {
Michal Kazior75d2bd42014-12-12 12:41:39 +01004637 case NL80211_IFTYPE_P2P_DEVICE:
4638 arvif->vdev_type = WMI_VDEV_TYPE_STA;
Peter Oh6e4de1a2016-01-28 13:54:10 -08004639 arvif->vdev_subtype = ath10k_wmi_get_vdev_subtype
4640 (ar, WMI_VDEV_SUBTYPE_P2P_DEVICE);
Michal Kazior75d2bd42014-12-12 12:41:39 +01004641 break;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004642 case NL80211_IFTYPE_UNSPECIFIED:
4643 case NL80211_IFTYPE_STATION:
4644 arvif->vdev_type = WMI_VDEV_TYPE_STA;
4645 if (vif->p2p)
Peter Oh6e4de1a2016-01-28 13:54:10 -08004646 arvif->vdev_subtype = ath10k_wmi_get_vdev_subtype
4647 (ar, WMI_VDEV_SUBTYPE_P2P_CLIENT);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004648 break;
4649 case NL80211_IFTYPE_ADHOC:
4650 arvif->vdev_type = WMI_VDEV_TYPE_IBSS;
4651 break;
Bob Copelandb6c7baf2015-09-09 12:47:36 -04004652 case NL80211_IFTYPE_MESH_POINT:
Peter Oh0b3d76e2016-01-28 13:54:07 -08004653 if (test_bit(WMI_SERVICE_MESH_11S, ar->wmi.svc_map)) {
Peter Oh6e4de1a2016-01-28 13:54:10 -08004654 arvif->vdev_subtype = ath10k_wmi_get_vdev_subtype
4655 (ar, WMI_VDEV_SUBTYPE_MESH_11S);
Peter Ohbb58b892015-11-24 09:37:35 -08004656 } else if (!test_bit(ATH10K_FLAG_RAW_MODE, &ar->dev_flags)) {
Bob Copelandb6c7baf2015-09-09 12:47:36 -04004657 ret = -EINVAL;
4658 ath10k_warn(ar, "must load driver with rawmode=1 to add mesh interfaces\n");
4659 goto err;
4660 }
4661 arvif->vdev_type = WMI_VDEV_TYPE_AP;
4662 break;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004663 case NL80211_IFTYPE_AP:
4664 arvif->vdev_type = WMI_VDEV_TYPE_AP;
4665
4666 if (vif->p2p)
Peter Oh6e4de1a2016-01-28 13:54:10 -08004667 arvif->vdev_subtype = ath10k_wmi_get_vdev_subtype
4668 (ar, WMI_VDEV_SUBTYPE_P2P_GO);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004669 break;
4670 case NL80211_IFTYPE_MONITOR:
4671 arvif->vdev_type = WMI_VDEV_TYPE_MONITOR;
4672 break;
4673 default:
4674 WARN_ON(1);
4675 break;
4676 }
4677
Michal Kazior96d828d2015-03-31 10:26:23 +00004678 /* Using vdev_id as queue number will make it very easy to do per-vif
4679 * tx queue locking. This shouldn't wrap due to interface combinations
4680 * but do a modulo for correctness sake and prevent using offchannel tx
4681 * queues for regular vif tx.
4682 */
4683 vif->cab_queue = arvif->vdev_id % (IEEE80211_MAX_QUEUES - 1);
4684 for (i = 0; i < ARRAY_SIZE(vif->hw_queue); i++)
4685 vif->hw_queue[i] = arvif->vdev_id % (IEEE80211_MAX_QUEUES - 1);
4686
Michal Kazior64badcb2014-09-18 11:18:02 +03004687 /* Some firmware revisions don't wait for beacon tx completion before
4688 * sending another SWBA event. This could lead to hardware using old
4689 * (freed) beacon data in some cases, e.g. tx credit starvation
4690 * combined with missed TBTT. This is very very rare.
4691 *
4692 * On non-IOMMU-enabled hosts this could be a possible security issue
4693 * because hw could beacon some random data on the air. On
4694 * IOMMU-enabled hosts DMAR faults would occur in most cases and target
4695 * device would crash.
4696 *
4697 * Since there are no beacon tx completions (implicit nor explicit)
4698 * propagated to host the only workaround for this is to allocate a
4699 * DMA-coherent buffer for a lifetime of a vif and use it for all
4700 * beacon tx commands. Worst case for this approach is some beacons may
4701 * become corrupted, e.g. have garbled IEs or out-of-date TIM bitmap.
4702 */
4703 if (vif->type == NL80211_IFTYPE_ADHOC ||
Bob Copelandb6c7baf2015-09-09 12:47:36 -04004704 vif->type == NL80211_IFTYPE_MESH_POINT ||
Michal Kazior64badcb2014-09-18 11:18:02 +03004705 vif->type == NL80211_IFTYPE_AP) {
4706 arvif->beacon_buf = dma_zalloc_coherent(ar->dev,
4707 IEEE80211_MAX_FRAME_LEN,
4708 &arvif->beacon_paddr,
Rajkumar Manoharan82d7aba2014-10-10 17:38:27 +05304709 GFP_ATOMIC);
Michal Kazior64badcb2014-09-18 11:18:02 +03004710 if (!arvif->beacon_buf) {
4711 ret = -ENOMEM;
4712 ath10k_warn(ar, "failed to allocate beacon buffer: %d\n",
4713 ret);
4714 goto err;
4715 }
4716 }
David Liuccec9032015-07-24 20:25:32 +03004717 if (test_bit(ATH10K_FLAG_HW_CRYPTO_DISABLED, &ar->dev_flags))
4718 arvif->nohwcrypt = true;
4719
4720 if (arvif->nohwcrypt &&
4721 !test_bit(ATH10K_FLAG_RAW_MODE, &ar->dev_flags)) {
4722 ath10k_warn(ar, "cryptmode module param needed for sw crypto\n");
4723 goto err;
4724 }
Michal Kazior64badcb2014-09-18 11:18:02 +03004725
4726 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev create %d (add interface) type %d subtype %d bcnmode %s\n",
4727 arvif->vdev_id, arvif->vdev_type, arvif->vdev_subtype,
4728 arvif->beacon_buf ? "single-buf" : "per-skb");
Kalle Valo5e3dd152013-06-12 20:52:10 +03004729
4730 ret = ath10k_wmi_vdev_create(ar, arvif->vdev_id, arvif->vdev_type,
4731 arvif->vdev_subtype, vif->addr);
4732 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004733 ath10k_warn(ar, "failed to create WMI vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004734 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004735 goto err;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004736 }
4737
Ben Greear16c11172014-09-23 14:17:16 -07004738 ar->free_vdev_map &= ~(1LL << arvif->vdev_id);
Michal Kazior05791192013-10-16 15:44:45 +03004739 list_add(&arvif->list, &ar->arvifs);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004740
Michal Kazior46725b152015-01-28 09:57:49 +02004741 /* It makes no sense to have firmware do keepalives. mac80211 already
4742 * takes care of this with idle connection polling.
4743 */
4744 ret = ath10k_mac_vif_disable_keepalive(arvif);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004745 if (ret) {
Michal Kazior46725b152015-01-28 09:57:49 +02004746 ath10k_warn(ar, "failed to disable keepalive on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004747 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004748 goto err_vdev_delete;
4749 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004750
SenthilKumar Jegadeesan627613f2015-01-29 13:50:38 +02004751 arvif->def_wep_key_idx = -1;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004752
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02004753 vdev_param = ar->wmi.vdev_param->tx_encap_type;
4754 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03004755 ATH10K_HW_TXRX_NATIVE_WIFI);
Bartosz Markowskiebc9abd2013-10-15 09:26:20 +02004756 /* 10.X firmware does not support this VDEV parameter. Do not warn */
Michal Kazior9dad14a2013-10-16 15:44:45 +03004757 if (ret && ret != -EOPNOTSUPP) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004758 ath10k_warn(ar, "failed to set vdev %i TX encapsulation: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004759 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004760 goto err_vdev_delete;
4761 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004762
Ben Greear5572a952014-11-24 16:22:10 +02004763 if (ar->cfg_tx_chainmask) {
4764 u16 nss = get_nss_from_chainmask(ar->cfg_tx_chainmask);
4765
4766 vdev_param = ar->wmi.vdev_param->nss;
4767 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
4768 nss);
4769 if (ret) {
4770 ath10k_warn(ar, "failed to set vdev %i chainmask 0x%x, nss %i: %d\n",
4771 arvif->vdev_id, ar->cfg_tx_chainmask, nss,
4772 ret);
4773 goto err_vdev_delete;
4774 }
4775 }
4776
Michal Kaziore57e0572015-03-24 13:14:03 +00004777 if (arvif->vdev_type == WMI_VDEV_TYPE_AP ||
4778 arvif->vdev_type == WMI_VDEV_TYPE_IBSS) {
Michal Kazior69427262016-03-06 16:14:30 +02004779 ret = ath10k_peer_create(ar, vif, NULL, arvif->vdev_id,
4780 vif->addr, WMI_PEER_TYPE_DEFAULT);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004781 if (ret) {
Michal Kaziore57e0572015-03-24 13:14:03 +00004782 ath10k_warn(ar, "failed to create vdev %i peer for AP/IBSS: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004783 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004784 goto err_vdev_delete;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004785 }
Michal Kaziorbb8f0c62016-03-06 16:14:27 +02004786
4787 spin_lock_bh(&ar->data_lock);
4788
4789 peer = ath10k_peer_find(ar, arvif->vdev_id, vif->addr);
4790 if (!peer) {
4791 ath10k_warn(ar, "failed to lookup peer %pM on vdev %i\n",
4792 vif->addr, arvif->vdev_id);
4793 spin_unlock_bh(&ar->data_lock);
4794 ret = -ENOENT;
4795 goto err_peer_delete;
4796 }
4797
4798 arvif->peer_id = find_first_bit(peer->peer_ids,
4799 ATH10K_MAX_NUM_PEER_IDS);
4800
4801 spin_unlock_bh(&ar->data_lock);
4802 } else {
4803 arvif->peer_id = HTT_INVALID_PEERID;
Michal Kaziore57e0572015-03-24 13:14:03 +00004804 }
Marek Puzyniakcdf07402013-12-30 09:07:51 +01004805
Michal Kaziore57e0572015-03-24 13:14:03 +00004806 if (arvif->vdev_type == WMI_VDEV_TYPE_AP) {
Kalle Valo5a13e762014-01-20 11:01:46 +02004807 ret = ath10k_mac_set_kickout(arvif);
4808 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004809 ath10k_warn(ar, "failed to set vdev %i kickout parameters: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004810 arvif->vdev_id, ret);
Kalle Valo5a13e762014-01-20 11:01:46 +02004811 goto err_peer_delete;
4812 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004813 }
4814
4815 if (arvif->vdev_type == WMI_VDEV_TYPE_STA) {
4816 param = WMI_STA_PS_PARAM_RX_WAKE_POLICY;
4817 value = WMI_STA_PS_RX_WAKE_POLICY_WAKE;
4818 ret = ath10k_wmi_set_sta_ps_param(ar, arvif->vdev_id,
4819 param, value);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004820 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004821 ath10k_warn(ar, "failed to set vdev %i RX wake policy: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004822 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004823 goto err_peer_delete;
4824 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004825
Michal Kazior9f9b5742014-12-12 12:41:36 +01004826 ret = ath10k_mac_vif_recalc_ps_wake_threshold(arvif);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004827 if (ret) {
Michal Kazior9f9b5742014-12-12 12:41:36 +01004828 ath10k_warn(ar, "failed to recalc ps wake threshold on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004829 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004830 goto err_peer_delete;
4831 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004832
Michal Kazior9f9b5742014-12-12 12:41:36 +01004833 ret = ath10k_mac_vif_recalc_ps_poll_count(arvif);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004834 if (ret) {
Michal Kazior9f9b5742014-12-12 12:41:36 +01004835 ath10k_warn(ar, "failed to recalc ps poll count on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004836 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004837 goto err_peer_delete;
4838 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004839 }
4840
Vivek Natarajana48e2cc2015-08-04 10:45:12 +05304841 ret = ath10k_mac_set_txbf_conf(arvif);
4842 if (ret) {
4843 ath10k_warn(ar, "failed to set txbf for vdev %d: %d\n",
4844 arvif->vdev_id, ret);
4845 goto err_peer_delete;
4846 }
4847
Michal Kazior424121c2013-07-22 14:13:31 +02004848 ret = ath10k_mac_set_rts(arvif, ar->hw->wiphy->rts_threshold);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004849 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004850 ath10k_warn(ar, "failed to set rts threshold for vdev %d: %d\n",
Michal Kazior679c54a2013-07-05 16:15:04 +03004851 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004852 goto err_peer_delete;
4853 }
Michal Kazior679c54a2013-07-05 16:15:04 +03004854
Michal Kazior7d9d5582014-10-21 10:40:15 +03004855 arvif->txpower = vif->bss_conf.txpower;
4856 ret = ath10k_mac_txpower_recalc(ar);
4857 if (ret) {
4858 ath10k_warn(ar, "failed to recalc tx power: %d\n", ret);
4859 goto err_peer_delete;
4860 }
4861
Michal Kazior500ff9f2015-03-31 10:26:21 +00004862 if (vif->type == NL80211_IFTYPE_MONITOR) {
4863 ar->monitor_arvif = arvif;
4864 ret = ath10k_monitor_recalc(ar);
4865 if (ret) {
4866 ath10k_warn(ar, "failed to recalc monitor: %d\n", ret);
4867 goto err_peer_delete;
4868 }
4869 }
4870
Michal Kazior6d2d51e2015-08-07 09:08:21 +02004871 spin_lock_bh(&ar->htt.tx_lock);
4872 if (!ar->tx_paused)
4873 ieee80211_wake_queue(ar->hw, arvif->vdev_id);
4874 spin_unlock_bh(&ar->htt.tx_lock);
4875
Kalle Valo5e3dd152013-06-12 20:52:10 +03004876 mutex_unlock(&ar->conf_mutex);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004877 return 0;
4878
4879err_peer_delete:
Michal Kaziore57e0572015-03-24 13:14:03 +00004880 if (arvif->vdev_type == WMI_VDEV_TYPE_AP ||
4881 arvif->vdev_type == WMI_VDEV_TYPE_IBSS)
Michal Kazior9dad14a2013-10-16 15:44:45 +03004882 ath10k_wmi_peer_delete(ar, arvif->vdev_id, vif->addr);
4883
4884err_vdev_delete:
4885 ath10k_wmi_vdev_delete(ar, arvif->vdev_id);
Ben Greear16c11172014-09-23 14:17:16 -07004886 ar->free_vdev_map |= 1LL << arvif->vdev_id;
Michal Kazior05791192013-10-16 15:44:45 +03004887 list_del(&arvif->list);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004888
4889err:
Michal Kazior64badcb2014-09-18 11:18:02 +03004890 if (arvif->beacon_buf) {
4891 dma_free_coherent(ar->dev, IEEE80211_MAX_FRAME_LEN,
4892 arvif->beacon_buf, arvif->beacon_paddr);
4893 arvif->beacon_buf = NULL;
4894 }
4895
Michal Kazior9dad14a2013-10-16 15:44:45 +03004896 mutex_unlock(&ar->conf_mutex);
4897
Kalle Valo5e3dd152013-06-12 20:52:10 +03004898 return ret;
4899}
4900
Michal Kaziorb4aa5392015-03-31 10:26:24 +00004901static void ath10k_mac_vif_tx_unlock_all(struct ath10k_vif *arvif)
4902{
4903 int i;
4904
4905 for (i = 0; i < BITS_PER_LONG; i++)
4906 ath10k_mac_vif_tx_unlock(arvif, i);
4907}
4908
Kalle Valo5e3dd152013-06-12 20:52:10 +03004909static void ath10k_remove_interface(struct ieee80211_hw *hw,
4910 struct ieee80211_vif *vif)
4911{
4912 struct ath10k *ar = hw->priv;
4913 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kazior69427262016-03-06 16:14:30 +02004914 struct ath10k_peer *peer;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004915 int ret;
Michal Kazior69427262016-03-06 16:14:30 +02004916 int i;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004917
Michal Kazior81a9a172015-03-05 16:02:17 +02004918 cancel_work_sync(&arvif->ap_csa_work);
Michal Kaziorcc9904e2015-03-10 16:22:01 +02004919 cancel_delayed_work_sync(&arvif->connection_loss_work);
Michal Kazior81a9a172015-03-05 16:02:17 +02004920
Sujith Manoharan5d011f52014-11-25 11:47:00 +05304921 mutex_lock(&ar->conf_mutex);
4922
Michal Kaziored543882013-09-13 14:16:56 +02004923 spin_lock_bh(&ar->data_lock);
Michal Kazior64badcb2014-09-18 11:18:02 +03004924 ath10k_mac_vif_beacon_cleanup(arvif);
Michal Kaziored543882013-09-13 14:16:56 +02004925 spin_unlock_bh(&ar->data_lock);
4926
Simon Wunderlich855aed12014-08-02 09:12:54 +03004927 ret = ath10k_spectral_vif_stop(arvif);
4928 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02004929 ath10k_warn(ar, "failed to stop spectral for vdev %i: %d\n",
Simon Wunderlich855aed12014-08-02 09:12:54 +03004930 arvif->vdev_id, ret);
4931
Ben Greear16c11172014-09-23 14:17:16 -07004932 ar->free_vdev_map |= 1LL << arvif->vdev_id;
Michal Kazior05791192013-10-16 15:44:45 +03004933 list_del(&arvif->list);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004934
Michal Kaziore57e0572015-03-24 13:14:03 +00004935 if (arvif->vdev_type == WMI_VDEV_TYPE_AP ||
4936 arvif->vdev_type == WMI_VDEV_TYPE_IBSS) {
Michal Kazior2c512052015-02-15 16:50:40 +02004937 ret = ath10k_wmi_peer_delete(arvif->ar, arvif->vdev_id,
4938 vif->addr);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004939 if (ret)
Michal Kaziore57e0572015-03-24 13:14:03 +00004940 ath10k_warn(ar, "failed to submit AP/IBSS self-peer removal on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004941 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004942
4943 kfree(arvif->u.ap.noa_data);
4944 }
4945
Michal Kazior7aa7a722014-08-25 12:09:38 +02004946 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %i delete (remove interface)\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03004947 arvif->vdev_id);
4948
Kalle Valo5e3dd152013-06-12 20:52:10 +03004949 ret = ath10k_wmi_vdev_delete(ar, arvif->vdev_id);
4950 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02004951 ath10k_warn(ar, "failed to delete WMI vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004952 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004953
Michal Kazior2c512052015-02-15 16:50:40 +02004954 /* Some firmware revisions don't notify host about self-peer removal
4955 * until after associated vdev is deleted.
4956 */
Michal Kaziore57e0572015-03-24 13:14:03 +00004957 if (arvif->vdev_type == WMI_VDEV_TYPE_AP ||
4958 arvif->vdev_type == WMI_VDEV_TYPE_IBSS) {
Michal Kazior2c512052015-02-15 16:50:40 +02004959 ret = ath10k_wait_for_peer_deleted(ar, arvif->vdev_id,
4960 vif->addr);
4961 if (ret)
4962 ath10k_warn(ar, "failed to remove AP self-peer on vdev %i: %d\n",
4963 arvif->vdev_id, ret);
4964
4965 spin_lock_bh(&ar->data_lock);
4966 ar->num_peers--;
4967 spin_unlock_bh(&ar->data_lock);
4968 }
4969
Michal Kazior69427262016-03-06 16:14:30 +02004970 spin_lock_bh(&ar->data_lock);
4971 for (i = 0; i < ARRAY_SIZE(ar->peer_map); i++) {
4972 peer = ar->peer_map[i];
4973 if (!peer)
4974 continue;
4975
4976 if (peer->vif == vif) {
4977 ath10k_warn(ar, "found vif peer %pM entry on vdev %i after it was supposedly removed\n",
4978 vif->addr, arvif->vdev_id);
4979 peer->vif = NULL;
4980 }
4981 }
4982 spin_unlock_bh(&ar->data_lock);
4983
Kalle Valo5e3dd152013-06-12 20:52:10 +03004984 ath10k_peer_cleanup(ar, arvif->vdev_id);
4985
Michal Kazior500ff9f2015-03-31 10:26:21 +00004986 if (vif->type == NL80211_IFTYPE_MONITOR) {
4987 ar->monitor_arvif = NULL;
4988 ret = ath10k_monitor_recalc(ar);
4989 if (ret)
4990 ath10k_warn(ar, "failed to recalc monitor: %d\n", ret);
4991 }
4992
Michal Kaziorb4aa5392015-03-31 10:26:24 +00004993 spin_lock_bh(&ar->htt.tx_lock);
4994 ath10k_mac_vif_tx_unlock_all(arvif);
4995 spin_unlock_bh(&ar->htt.tx_lock);
4996
Michal Kazior29946872016-03-06 16:14:34 +02004997 ath10k_mac_txq_unref(ar, vif->txq);
4998
Kalle Valo5e3dd152013-06-12 20:52:10 +03004999 mutex_unlock(&ar->conf_mutex);
5000}
5001
5002/*
5003 * FIXME: Has to be verified.
5004 */
5005#define SUPPORTED_FILTERS \
Johannes Bergdf140462015-04-22 14:40:58 +02005006 (FIF_ALLMULTI | \
Kalle Valo5e3dd152013-06-12 20:52:10 +03005007 FIF_CONTROL | \
5008 FIF_PSPOLL | \
5009 FIF_OTHER_BSS | \
5010 FIF_BCN_PRBRESP_PROMISC | \
5011 FIF_PROBE_REQ | \
5012 FIF_FCSFAIL)
5013
5014static void ath10k_configure_filter(struct ieee80211_hw *hw,
5015 unsigned int changed_flags,
5016 unsigned int *total_flags,
5017 u64 multicast)
5018{
5019 struct ath10k *ar = hw->priv;
5020 int ret;
5021
5022 mutex_lock(&ar->conf_mutex);
5023
5024 changed_flags &= SUPPORTED_FILTERS;
5025 *total_flags &= SUPPORTED_FILTERS;
5026 ar->filter_flags = *total_flags;
5027
Michal Kazior19337472014-08-28 12:58:16 +02005028 ret = ath10k_monitor_recalc(ar);
5029 if (ret)
5030 ath10k_warn(ar, "failed to recalc montior: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005031
5032 mutex_unlock(&ar->conf_mutex);
5033}
5034
5035static void ath10k_bss_info_changed(struct ieee80211_hw *hw,
5036 struct ieee80211_vif *vif,
5037 struct ieee80211_bss_conf *info,
5038 u32 changed)
5039{
5040 struct ath10k *ar = hw->priv;
5041 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
5042 int ret = 0;
Kalle Valoaf762c02014-09-14 12:50:17 +03005043 u32 vdev_param, pdev_param, slottime, preamble;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005044
5045 mutex_lock(&ar->conf_mutex);
5046
5047 if (changed & BSS_CHANGED_IBSS)
5048 ath10k_control_ibss(arvif, info, vif->addr);
5049
5050 if (changed & BSS_CHANGED_BEACON_INT) {
5051 arvif->beacon_interval = info->beacon_int;
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02005052 vdev_param = ar->wmi.vdev_param->beacon_interval;
5053 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03005054 arvif->beacon_interval);
Michal Kazior7aa7a722014-08-25 12:09:38 +02005055 ath10k_dbg(ar, ATH10K_DBG_MAC,
Kalle Valo60c3daa2013-09-08 17:56:07 +03005056 "mac vdev %d beacon_interval %d\n",
5057 arvif->vdev_id, arvif->beacon_interval);
5058
Kalle Valo5e3dd152013-06-12 20:52:10 +03005059 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005060 ath10k_warn(ar, "failed to set beacon interval for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02005061 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005062 }
5063
5064 if (changed & BSS_CHANGED_BEACON) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005065 ath10k_dbg(ar, ATH10K_DBG_MAC,
Kalle Valo60c3daa2013-09-08 17:56:07 +03005066 "vdev %d set beacon tx mode to staggered\n",
5067 arvif->vdev_id);
5068
Bartosz Markowski226a3392013-09-26 17:47:16 +02005069 pdev_param = ar->wmi.pdev_param->beacon_tx_mode;
5070 ret = ath10k_wmi_pdev_set_param(ar, pdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03005071 WMI_BEACON_STAGGERED_MODE);
5072 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005073 ath10k_warn(ar, "failed to set beacon mode for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02005074 arvif->vdev_id, ret);
Michal Kaziorfbb8f1b2015-01-13 16:30:12 +02005075
5076 ret = ath10k_mac_setup_bcn_tmpl(arvif);
5077 if (ret)
5078 ath10k_warn(ar, "failed to update beacon template: %d\n",
5079 ret);
Bob Copelandb6c7baf2015-09-09 12:47:36 -04005080
5081 if (ieee80211_vif_is_mesh(vif)) {
5082 /* mesh doesn't use SSID but firmware needs it */
5083 strncpy(arvif->u.ap.ssid, "mesh",
5084 sizeof(arvif->u.ap.ssid));
5085 arvif->u.ap.ssid_len = 4;
5086 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03005087 }
5088
Michal Kaziorfbb8f1b2015-01-13 16:30:12 +02005089 if (changed & BSS_CHANGED_AP_PROBE_RESP) {
5090 ret = ath10k_mac_setup_prb_tmpl(arvif);
5091 if (ret)
5092 ath10k_warn(ar, "failed to setup probe resp template on vdev %i: %d\n",
5093 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005094 }
5095
Michal Kaziorba2479f2015-01-24 12:14:51 +02005096 if (changed & (BSS_CHANGED_BEACON_INFO | BSS_CHANGED_BEACON)) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03005097 arvif->dtim_period = info->dtim_period;
5098
Michal Kazior7aa7a722014-08-25 12:09:38 +02005099 ath10k_dbg(ar, ATH10K_DBG_MAC,
Kalle Valo60c3daa2013-09-08 17:56:07 +03005100 "mac vdev %d dtim_period %d\n",
5101 arvif->vdev_id, arvif->dtim_period);
5102
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02005103 vdev_param = ar->wmi.vdev_param->dtim_period;
5104 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03005105 arvif->dtim_period);
5106 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005107 ath10k_warn(ar, "failed to set dtim period for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02005108 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005109 }
5110
5111 if (changed & BSS_CHANGED_SSID &&
5112 vif->type == NL80211_IFTYPE_AP) {
5113 arvif->u.ap.ssid_len = info->ssid_len;
5114 if (info->ssid_len)
5115 memcpy(arvif->u.ap.ssid, info->ssid, info->ssid_len);
5116 arvif->u.ap.hidden_ssid = info->hidden_ssid;
5117 }
5118
Michal Kazior077efc82014-10-21 10:10:29 +03005119 if (changed & BSS_CHANGED_BSSID && !is_zero_ether_addr(info->bssid))
5120 ether_addr_copy(arvif->bssid, info->bssid);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005121
5122 if (changed & BSS_CHANGED_BEACON_ENABLED)
5123 ath10k_control_beaconing(arvif, info);
5124
5125 if (changed & BSS_CHANGED_ERP_CTS_PROT) {
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02005126 arvif->use_cts_prot = info->use_cts_prot;
Michal Kazior7aa7a722014-08-25 12:09:38 +02005127 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %d cts_prot %d\n",
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02005128 arvif->vdev_id, info->use_cts_prot);
Kalle Valo60c3daa2013-09-08 17:56:07 +03005129
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02005130 ret = ath10k_recalc_rtscts_prot(arvif);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005131 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005132 ath10k_warn(ar, "failed to recalculate rts/cts prot for vdev %d: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02005133 arvif->vdev_id, ret);
Michal Kaziora87fd4b2015-03-02 11:21:17 +01005134
5135 vdev_param = ar->wmi.vdev_param->protection_mode;
5136 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
5137 info->use_cts_prot ? 1 : 0);
5138 if (ret)
5139 ath10k_warn(ar, "failed to set protection mode %d on vdev %i: %d\n",
Kalle Valo617b0f42015-10-05 17:56:35 +03005140 info->use_cts_prot, arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005141 }
5142
5143 if (changed & BSS_CHANGED_ERP_SLOT) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03005144 if (info->use_short_slot)
5145 slottime = WMI_VDEV_SLOT_TIME_SHORT; /* 9us */
5146
5147 else
5148 slottime = WMI_VDEV_SLOT_TIME_LONG; /* 20us */
5149
Michal Kazior7aa7a722014-08-25 12:09:38 +02005150 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %d slot_time %d\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03005151 arvif->vdev_id, slottime);
5152
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02005153 vdev_param = ar->wmi.vdev_param->slot_time;
5154 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03005155 slottime);
5156 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005157 ath10k_warn(ar, "failed to set erp slot for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02005158 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005159 }
5160
5161 if (changed & BSS_CHANGED_ERP_PREAMBLE) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03005162 if (info->use_short_preamble)
5163 preamble = WMI_VDEV_PREAMBLE_SHORT;
5164 else
5165 preamble = WMI_VDEV_PREAMBLE_LONG;
5166
Michal Kazior7aa7a722014-08-25 12:09:38 +02005167 ath10k_dbg(ar, ATH10K_DBG_MAC,
Kalle Valo60c3daa2013-09-08 17:56:07 +03005168 "mac vdev %d preamble %dn",
5169 arvif->vdev_id, preamble);
5170
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02005171 vdev_param = ar->wmi.vdev_param->preamble;
5172 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03005173 preamble);
5174 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005175 ath10k_warn(ar, "failed to set preamble for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02005176 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005177 }
5178
5179 if (changed & BSS_CHANGED_ASSOC) {
Michal Kaziore556f112014-08-28 12:58:17 +02005180 if (info->assoc) {
5181 /* Workaround: Make sure monitor vdev is not running
5182 * when associating to prevent some firmware revisions
5183 * (e.g. 10.1 and 10.2) from crashing.
5184 */
5185 if (ar->monitor_started)
5186 ath10k_monitor_stop(ar);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005187 ath10k_bss_assoc(hw, vif, info);
Michal Kaziore556f112014-08-28 12:58:17 +02005188 ath10k_monitor_recalc(ar);
Michal Kazior077efc82014-10-21 10:10:29 +03005189 } else {
5190 ath10k_bss_disassoc(hw, vif);
Michal Kaziore556f112014-08-28 12:58:17 +02005191 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03005192 }
5193
Michal Kazior7d9d5582014-10-21 10:40:15 +03005194 if (changed & BSS_CHANGED_TXPOWER) {
5195 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev_id %i txpower %d\n",
5196 arvif->vdev_id, info->txpower);
5197
5198 arvif->txpower = info->txpower;
5199 ret = ath10k_mac_txpower_recalc(ar);
5200 if (ret)
5201 ath10k_warn(ar, "failed to recalc tx power: %d\n", ret);
5202 }
5203
Michal Kaziorbf14e652014-12-12 12:41:38 +01005204 if (changed & BSS_CHANGED_PS) {
Michal Kaziorcffb41f2015-02-13 13:30:16 +01005205 arvif->ps = vif->bss_conf.ps;
5206
5207 ret = ath10k_config_ps(ar);
Michal Kaziorbf14e652014-12-12 12:41:38 +01005208 if (ret)
5209 ath10k_warn(ar, "failed to setup ps on vdev %i: %d\n",
5210 arvif->vdev_id, ret);
5211 }
5212
Kalle Valo5e3dd152013-06-12 20:52:10 +03005213 mutex_unlock(&ar->conf_mutex);
5214}
5215
5216static int ath10k_hw_scan(struct ieee80211_hw *hw,
5217 struct ieee80211_vif *vif,
David Spinadelc56ef672014-02-05 15:21:13 +02005218 struct ieee80211_scan_request *hw_req)
Kalle Valo5e3dd152013-06-12 20:52:10 +03005219{
5220 struct ath10k *ar = hw->priv;
5221 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
David Spinadelc56ef672014-02-05 15:21:13 +02005222 struct cfg80211_scan_request *req = &hw_req->req;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005223 struct wmi_start_scan_arg arg;
5224 int ret = 0;
5225 int i;
5226
5227 mutex_lock(&ar->conf_mutex);
5228
5229 spin_lock_bh(&ar->data_lock);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005230 switch (ar->scan.state) {
5231 case ATH10K_SCAN_IDLE:
5232 reinit_completion(&ar->scan.started);
5233 reinit_completion(&ar->scan.completed);
5234 ar->scan.state = ATH10K_SCAN_STARTING;
5235 ar->scan.is_roc = false;
5236 ar->scan.vdev_id = arvif->vdev_id;
5237 ret = 0;
5238 break;
5239 case ATH10K_SCAN_STARTING:
5240 case ATH10K_SCAN_RUNNING:
5241 case ATH10K_SCAN_ABORTING:
Kalle Valo5e3dd152013-06-12 20:52:10 +03005242 ret = -EBUSY;
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005243 break;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005244 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03005245 spin_unlock_bh(&ar->data_lock);
5246
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005247 if (ret)
5248 goto exit;
5249
Kalle Valo5e3dd152013-06-12 20:52:10 +03005250 memset(&arg, 0, sizeof(arg));
5251 ath10k_wmi_start_scan_init(ar, &arg);
5252 arg.vdev_id = arvif->vdev_id;
5253 arg.scan_id = ATH10K_SCAN_ID;
5254
Kalle Valo5e3dd152013-06-12 20:52:10 +03005255 if (req->ie_len) {
5256 arg.ie_len = req->ie_len;
5257 memcpy(arg.ie, req->ie, arg.ie_len);
5258 }
5259
5260 if (req->n_ssids) {
5261 arg.n_ssids = req->n_ssids;
5262 for (i = 0; i < arg.n_ssids; i++) {
5263 arg.ssids[i].len = req->ssids[i].ssid_len;
5264 arg.ssids[i].ssid = req->ssids[i].ssid;
5265 }
Michal Kaziordcd4a562013-07-31 10:55:12 +02005266 } else {
5267 arg.scan_ctrl_flags |= WMI_SCAN_FLAG_PASSIVE;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005268 }
5269
5270 if (req->n_channels) {
5271 arg.n_channels = req->n_channels;
5272 for (i = 0; i < arg.n_channels; i++)
5273 arg.channels[i] = req->channels[i]->center_freq;
5274 }
5275
5276 ret = ath10k_start_scan(ar, &arg);
5277 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005278 ath10k_warn(ar, "failed to start hw scan: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005279 spin_lock_bh(&ar->data_lock);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005280 ar->scan.state = ATH10K_SCAN_IDLE;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005281 spin_unlock_bh(&ar->data_lock);
5282 }
5283
Michal Kazior634349b2015-09-03 10:43:45 +02005284 /* Add a 200ms margin to account for event/command processing */
5285 ieee80211_queue_delayed_work(ar->hw, &ar->scan.timeout,
5286 msecs_to_jiffies(arg.max_scan_time +
5287 200));
5288
Kalle Valo5e3dd152013-06-12 20:52:10 +03005289exit:
5290 mutex_unlock(&ar->conf_mutex);
5291 return ret;
5292}
5293
5294static void ath10k_cancel_hw_scan(struct ieee80211_hw *hw,
5295 struct ieee80211_vif *vif)
5296{
5297 struct ath10k *ar = hw->priv;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005298
5299 mutex_lock(&ar->conf_mutex);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005300 ath10k_scan_abort(ar);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005301 mutex_unlock(&ar->conf_mutex);
Michal Kazior4eb2e162014-10-28 10:23:09 +01005302
5303 cancel_delayed_work_sync(&ar->scan.timeout);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005304}
5305
Michal Kaziorcfb27d22013-12-02 09:06:36 +01005306static void ath10k_set_key_h_def_keyidx(struct ath10k *ar,
5307 struct ath10k_vif *arvif,
5308 enum set_key_cmd cmd,
5309 struct ieee80211_key_conf *key)
5310{
5311 u32 vdev_param = arvif->ar->wmi.vdev_param->def_keyid;
5312 int ret;
5313
5314 /* 10.1 firmware branch requires default key index to be set to group
5315 * key index after installing it. Otherwise FW/HW Txes corrupted
5316 * frames with multi-vif APs. This is not required for main firmware
5317 * branch (e.g. 636).
5318 *
Michal Kazior8461baf2015-04-10 13:23:22 +00005319 * This is also needed for 636 fw for IBSS-RSN to work more reliably.
5320 *
5321 * FIXME: It remains unknown if this is required for multi-vif STA
5322 * interfaces on 10.1.
5323 */
Michal Kaziorcfb27d22013-12-02 09:06:36 +01005324
Michal Kazior8461baf2015-04-10 13:23:22 +00005325 if (arvif->vdev_type != WMI_VDEV_TYPE_AP &&
5326 arvif->vdev_type != WMI_VDEV_TYPE_IBSS)
Michal Kaziorcfb27d22013-12-02 09:06:36 +01005327 return;
5328
5329 if (key->cipher == WLAN_CIPHER_SUITE_WEP40)
5330 return;
5331
5332 if (key->cipher == WLAN_CIPHER_SUITE_WEP104)
5333 return;
5334
5335 if (key->flags & IEEE80211_KEY_FLAG_PAIRWISE)
5336 return;
5337
5338 if (cmd != SET_KEY)
5339 return;
5340
5341 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
5342 key->keyidx);
5343 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005344 ath10k_warn(ar, "failed to set vdev %i group key as default key: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02005345 arvif->vdev_id, ret);
Michal Kaziorcfb27d22013-12-02 09:06:36 +01005346}
5347
Kalle Valo5e3dd152013-06-12 20:52:10 +03005348static int ath10k_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd,
5349 struct ieee80211_vif *vif, struct ieee80211_sta *sta,
5350 struct ieee80211_key_conf *key)
5351{
5352 struct ath10k *ar = hw->priv;
5353 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
5354 struct ath10k_peer *peer;
5355 const u8 *peer_addr;
5356 bool is_wep = key->cipher == WLAN_CIPHER_SUITE_WEP40 ||
5357 key->cipher == WLAN_CIPHER_SUITE_WEP104;
5358 int ret = 0;
Michal Kazior29a10002015-04-10 13:05:58 +00005359 int ret2;
Michal Kazior370e5672015-02-18 14:02:26 +01005360 u32 flags = 0;
Michal Kazior29a10002015-04-10 13:05:58 +00005361 u32 flags2;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005362
Bartosz Markowskid7131c02015-03-10 14:32:19 +01005363 /* this one needs to be done in software */
5364 if (key->cipher == WLAN_CIPHER_SUITE_AES_CMAC)
5365 return 1;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005366
David Liuccec9032015-07-24 20:25:32 +03005367 if (arvif->nohwcrypt)
5368 return 1;
5369
Kalle Valo5e3dd152013-06-12 20:52:10 +03005370 if (key->keyidx > WMI_MAX_KEY_INDEX)
5371 return -ENOSPC;
5372
5373 mutex_lock(&ar->conf_mutex);
5374
5375 if (sta)
5376 peer_addr = sta->addr;
5377 else if (arvif->vdev_type == WMI_VDEV_TYPE_STA)
5378 peer_addr = vif->bss_conf.bssid;
5379 else
5380 peer_addr = vif->addr;
5381
5382 key->hw_key_idx = key->keyidx;
5383
Michal Kazior7c8cc7e2015-04-01 22:53:19 +03005384 if (is_wep) {
5385 if (cmd == SET_KEY)
5386 arvif->wep_keys[key->keyidx] = key;
5387 else
5388 arvif->wep_keys[key->keyidx] = NULL;
5389 }
5390
Kalle Valo5e3dd152013-06-12 20:52:10 +03005391 /* the peer should not disappear in mid-way (unless FW goes awry) since
5392 * we already hold conf_mutex. we just make sure its there now. */
5393 spin_lock_bh(&ar->data_lock);
5394 peer = ath10k_peer_find(ar, arvif->vdev_id, peer_addr);
5395 spin_unlock_bh(&ar->data_lock);
5396
5397 if (!peer) {
5398 if (cmd == SET_KEY) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005399 ath10k_warn(ar, "failed to install key for non-existent peer %pM\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03005400 peer_addr);
5401 ret = -EOPNOTSUPP;
5402 goto exit;
5403 } else {
5404 /* if the peer doesn't exist there is no key to disable
5405 * anymore */
5406 goto exit;
5407 }
5408 }
5409
Michal Kazior7cc45732015-03-09 14:24:17 +01005410 if (key->flags & IEEE80211_KEY_FLAG_PAIRWISE)
5411 flags |= WMI_KEY_PAIRWISE;
5412 else
5413 flags |= WMI_KEY_GROUP;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005414
Kalle Valo5e3dd152013-06-12 20:52:10 +03005415 if (is_wep) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03005416 if (cmd == DISABLE_KEY)
5417 ath10k_clear_vdev_key(arvif, key);
Michal Kazior370e5672015-02-18 14:02:26 +01005418
Michal Kaziorad325cb2015-02-18 14:02:27 +01005419 /* When WEP keys are uploaded it's possible that there are
5420 * stations associated already (e.g. when merging) without any
5421 * keys. Static WEP needs an explicit per-peer key upload.
5422 */
5423 if (vif->type == NL80211_IFTYPE_ADHOC &&
5424 cmd == SET_KEY)
5425 ath10k_mac_vif_update_wep_key(arvif, key);
5426
Michal Kazior370e5672015-02-18 14:02:26 +01005427 /* 802.1x never sets the def_wep_key_idx so each set_key()
5428 * call changes default tx key.
5429 *
5430 * Static WEP sets def_wep_key_idx via .set_default_unicast_key
5431 * after first set_key().
5432 */
5433 if (cmd == SET_KEY && arvif->def_wep_key_idx == -1)
5434 flags |= WMI_KEY_TX_USAGE;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005435 }
5436
Michal Kazior370e5672015-02-18 14:02:26 +01005437 ret = ath10k_install_key(arvif, key, cmd, peer_addr, flags);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005438 if (ret) {
David Liuccec9032015-07-24 20:25:32 +03005439 WARN_ON(ret > 0);
Michal Kazior7aa7a722014-08-25 12:09:38 +02005440 ath10k_warn(ar, "failed to install key for vdev %i peer %pM: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02005441 arvif->vdev_id, peer_addr, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005442 goto exit;
5443 }
5444
Michal Kazior29a10002015-04-10 13:05:58 +00005445 /* mac80211 sets static WEP keys as groupwise while firmware requires
5446 * them to be installed twice as both pairwise and groupwise.
5447 */
5448 if (is_wep && !sta && vif->type == NL80211_IFTYPE_STATION) {
5449 flags2 = flags;
5450 flags2 &= ~WMI_KEY_GROUP;
5451 flags2 |= WMI_KEY_PAIRWISE;
5452
5453 ret = ath10k_install_key(arvif, key, cmd, peer_addr, flags2);
5454 if (ret) {
David Liuccec9032015-07-24 20:25:32 +03005455 WARN_ON(ret > 0);
Michal Kazior29a10002015-04-10 13:05:58 +00005456 ath10k_warn(ar, "failed to install (ucast) key for vdev %i peer %pM: %d\n",
5457 arvif->vdev_id, peer_addr, ret);
5458 ret2 = ath10k_install_key(arvif, key, DISABLE_KEY,
5459 peer_addr, flags);
David Liuccec9032015-07-24 20:25:32 +03005460 if (ret2) {
5461 WARN_ON(ret2 > 0);
Michal Kazior29a10002015-04-10 13:05:58 +00005462 ath10k_warn(ar, "failed to disable (mcast) key for vdev %i peer %pM: %d\n",
5463 arvif->vdev_id, peer_addr, ret2);
David Liuccec9032015-07-24 20:25:32 +03005464 }
Michal Kazior29a10002015-04-10 13:05:58 +00005465 goto exit;
5466 }
5467 }
5468
Michal Kaziorcfb27d22013-12-02 09:06:36 +01005469 ath10k_set_key_h_def_keyidx(ar, arvif, cmd, key);
5470
Kalle Valo5e3dd152013-06-12 20:52:10 +03005471 spin_lock_bh(&ar->data_lock);
5472 peer = ath10k_peer_find(ar, arvif->vdev_id, peer_addr);
5473 if (peer && cmd == SET_KEY)
5474 peer->keys[key->keyidx] = key;
5475 else if (peer && cmd == DISABLE_KEY)
5476 peer->keys[key->keyidx] = NULL;
5477 else if (peer == NULL)
5478 /* impossible unless FW goes crazy */
Michal Kazior7aa7a722014-08-25 12:09:38 +02005479 ath10k_warn(ar, "Peer %pM disappeared!\n", peer_addr);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005480 spin_unlock_bh(&ar->data_lock);
5481
5482exit:
5483 mutex_unlock(&ar->conf_mutex);
5484 return ret;
5485}
5486
SenthilKumar Jegadeesan627613f2015-01-29 13:50:38 +02005487static void ath10k_set_default_unicast_key(struct ieee80211_hw *hw,
5488 struct ieee80211_vif *vif,
5489 int keyidx)
5490{
5491 struct ath10k *ar = hw->priv;
5492 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
5493 int ret;
5494
5495 mutex_lock(&arvif->ar->conf_mutex);
5496
5497 if (arvif->ar->state != ATH10K_STATE_ON)
5498 goto unlock;
5499
5500 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %d set keyidx %d\n",
5501 arvif->vdev_id, keyidx);
5502
5503 ret = ath10k_wmi_vdev_set_param(arvif->ar,
5504 arvif->vdev_id,
5505 arvif->ar->wmi.vdev_param->def_keyid,
5506 keyidx);
5507
5508 if (ret) {
5509 ath10k_warn(ar, "failed to update wep key index for vdev %d: %d\n",
5510 arvif->vdev_id,
5511 ret);
5512 goto unlock;
5513 }
5514
5515 arvif->def_wep_key_idx = keyidx;
Michal Kazior370e5672015-02-18 14:02:26 +01005516
SenthilKumar Jegadeesan627613f2015-01-29 13:50:38 +02005517unlock:
5518 mutex_unlock(&arvif->ar->conf_mutex);
5519}
5520
Michal Kazior9797feb2014-02-14 14:49:48 +01005521static void ath10k_sta_rc_update_wk(struct work_struct *wk)
5522{
5523 struct ath10k *ar;
5524 struct ath10k_vif *arvif;
5525 struct ath10k_sta *arsta;
5526 struct ieee80211_sta *sta;
Michal Kazior45c9abc2015-04-21 20:42:58 +03005527 struct cfg80211_chan_def def;
5528 enum ieee80211_band band;
5529 const u8 *ht_mcs_mask;
5530 const u16 *vht_mcs_mask;
Michal Kazior9797feb2014-02-14 14:49:48 +01005531 u32 changed, bw, nss, smps;
5532 int err;
5533
5534 arsta = container_of(wk, struct ath10k_sta, update_wk);
5535 sta = container_of((void *)arsta, struct ieee80211_sta, drv_priv);
5536 arvif = arsta->arvif;
5537 ar = arvif->ar;
5538
Michal Kazior45c9abc2015-04-21 20:42:58 +03005539 if (WARN_ON(ath10k_mac_vif_chan(arvif->vif, &def)))
5540 return;
5541
5542 band = def.chan->band;
5543 ht_mcs_mask = arvif->bitrate_mask.control[band].ht_mcs;
5544 vht_mcs_mask = arvif->bitrate_mask.control[band].vht_mcs;
5545
Michal Kazior9797feb2014-02-14 14:49:48 +01005546 spin_lock_bh(&ar->data_lock);
5547
5548 changed = arsta->changed;
5549 arsta->changed = 0;
5550
5551 bw = arsta->bw;
5552 nss = arsta->nss;
5553 smps = arsta->smps;
5554
5555 spin_unlock_bh(&ar->data_lock);
5556
5557 mutex_lock(&ar->conf_mutex);
5558
Michal Kazior45c9abc2015-04-21 20:42:58 +03005559 nss = max_t(u32, 1, nss);
5560 nss = min(nss, max(ath10k_mac_max_ht_nss(ht_mcs_mask),
5561 ath10k_mac_max_vht_nss(vht_mcs_mask)));
5562
Michal Kazior9797feb2014-02-14 14:49:48 +01005563 if (changed & IEEE80211_RC_BW_CHANGED) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005564 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac update sta %pM peer bw %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01005565 sta->addr, bw);
5566
5567 err = ath10k_wmi_peer_set_param(ar, arvif->vdev_id, sta->addr,
5568 WMI_PEER_CHAN_WIDTH, bw);
5569 if (err)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005570 ath10k_warn(ar, "failed to update STA %pM peer bw %d: %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01005571 sta->addr, bw, err);
5572 }
5573
5574 if (changed & IEEE80211_RC_NSS_CHANGED) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005575 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac update sta %pM nss %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01005576 sta->addr, nss);
5577
5578 err = ath10k_wmi_peer_set_param(ar, arvif->vdev_id, sta->addr,
5579 WMI_PEER_NSS, nss);
5580 if (err)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005581 ath10k_warn(ar, "failed to update STA %pM nss %d: %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01005582 sta->addr, nss, err);
5583 }
5584
5585 if (changed & IEEE80211_RC_SMPS_CHANGED) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005586 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac update sta %pM smps %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01005587 sta->addr, smps);
5588
5589 err = ath10k_wmi_peer_set_param(ar, arvif->vdev_id, sta->addr,
5590 WMI_PEER_SMPS_STATE, smps);
5591 if (err)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005592 ath10k_warn(ar, "failed to update STA %pM smps %d: %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01005593 sta->addr, smps, err);
5594 }
5595
Janusz Dziedzic55884c02014-12-17 12:30:02 +02005596 if (changed & IEEE80211_RC_SUPP_RATES_CHANGED ||
5597 changed & IEEE80211_RC_NSS_CHANGED) {
5598 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac update sta %pM supp rates/nss\n",
Chun-Yeow Yeoh44d6fa92014-03-07 10:19:30 +02005599 sta->addr);
5600
Michal Kazior590922a2014-10-21 10:10:29 +03005601 err = ath10k_station_assoc(ar, arvif->vif, sta, true);
Chun-Yeow Yeoh44d6fa92014-03-07 10:19:30 +02005602 if (err)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005603 ath10k_warn(ar, "failed to reassociate station: %pM\n",
Chun-Yeow Yeoh44d6fa92014-03-07 10:19:30 +02005604 sta->addr);
5605 }
5606
Michal Kazior9797feb2014-02-14 14:49:48 +01005607 mutex_unlock(&ar->conf_mutex);
5608}
5609
Marek Puzyniak7c354242015-03-30 09:51:52 +03005610static int ath10k_mac_inc_num_stations(struct ath10k_vif *arvif,
5611 struct ieee80211_sta *sta)
Michal Kaziorcfd10612014-11-25 15:16:05 +01005612{
5613 struct ath10k *ar = arvif->ar;
5614
5615 lockdep_assert_held(&ar->conf_mutex);
5616
Marek Puzyniak7c354242015-03-30 09:51:52 +03005617 if (arvif->vdev_type == WMI_VDEV_TYPE_STA && !sta->tdls)
Michal Kaziorcfd10612014-11-25 15:16:05 +01005618 return 0;
5619
5620 if (ar->num_stations >= ar->max_num_stations)
5621 return -ENOBUFS;
5622
5623 ar->num_stations++;
5624
5625 return 0;
5626}
5627
Marek Puzyniak7c354242015-03-30 09:51:52 +03005628static void ath10k_mac_dec_num_stations(struct ath10k_vif *arvif,
5629 struct ieee80211_sta *sta)
Michal Kaziorcfd10612014-11-25 15:16:05 +01005630{
5631 struct ath10k *ar = arvif->ar;
5632
5633 lockdep_assert_held(&ar->conf_mutex);
5634
Marek Puzyniak7c354242015-03-30 09:51:52 +03005635 if (arvif->vdev_type == WMI_VDEV_TYPE_STA && !sta->tdls)
Michal Kaziorcfd10612014-11-25 15:16:05 +01005636 return;
5637
5638 ar->num_stations--;
5639}
5640
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005641struct ath10k_mac_tdls_iter_data {
5642 u32 num_tdls_stations;
5643 struct ieee80211_vif *curr_vif;
5644};
5645
5646static void ath10k_mac_tdls_vif_stations_count_iter(void *data,
5647 struct ieee80211_sta *sta)
5648{
5649 struct ath10k_mac_tdls_iter_data *iter_data = data;
5650 struct ath10k_sta *arsta = (struct ath10k_sta *)sta->drv_priv;
5651 struct ieee80211_vif *sta_vif = arsta->arvif->vif;
5652
5653 if (sta->tdls && sta_vif == iter_data->curr_vif)
5654 iter_data->num_tdls_stations++;
5655}
5656
5657static int ath10k_mac_tdls_vif_stations_count(struct ieee80211_hw *hw,
5658 struct ieee80211_vif *vif)
5659{
5660 struct ath10k_mac_tdls_iter_data data = {};
5661
5662 data.curr_vif = vif;
5663
5664 ieee80211_iterate_stations_atomic(hw,
5665 ath10k_mac_tdls_vif_stations_count_iter,
5666 &data);
5667 return data.num_tdls_stations;
5668}
5669
5670static void ath10k_mac_tdls_vifs_count_iter(void *data, u8 *mac,
5671 struct ieee80211_vif *vif)
5672{
5673 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
5674 int *num_tdls_vifs = data;
5675
5676 if (vif->type != NL80211_IFTYPE_STATION)
5677 return;
5678
5679 if (ath10k_mac_tdls_vif_stations_count(arvif->ar->hw, vif) > 0)
5680 (*num_tdls_vifs)++;
5681}
5682
5683static int ath10k_mac_tdls_vifs_count(struct ieee80211_hw *hw)
5684{
5685 int num_tdls_vifs = 0;
5686
5687 ieee80211_iterate_active_interfaces_atomic(hw,
5688 IEEE80211_IFACE_ITER_NORMAL,
5689 ath10k_mac_tdls_vifs_count_iter,
5690 &num_tdls_vifs);
5691 return num_tdls_vifs;
5692}
5693
Kalle Valo5e3dd152013-06-12 20:52:10 +03005694static int ath10k_sta_state(struct ieee80211_hw *hw,
5695 struct ieee80211_vif *vif,
5696 struct ieee80211_sta *sta,
5697 enum ieee80211_sta_state old_state,
5698 enum ieee80211_sta_state new_state)
5699{
5700 struct ath10k *ar = hw->priv;
5701 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kazior9797feb2014-02-14 14:49:48 +01005702 struct ath10k_sta *arsta = (struct ath10k_sta *)sta->drv_priv;
Michal Kaziorbb8f0c62016-03-06 16:14:27 +02005703 struct ath10k_peer *peer;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005704 int ret = 0;
Michal Kazior69427262016-03-06 16:14:30 +02005705 int i;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005706
Michal Kazior76f90022014-02-25 09:29:57 +02005707 if (old_state == IEEE80211_STA_NOTEXIST &&
5708 new_state == IEEE80211_STA_NONE) {
5709 memset(arsta, 0, sizeof(*arsta));
5710 arsta->arvif = arvif;
5711 INIT_WORK(&arsta->update_wk, ath10k_sta_rc_update_wk);
Michal Kazior29946872016-03-06 16:14:34 +02005712
5713 for (i = 0; i < ARRAY_SIZE(sta->txq); i++)
5714 ath10k_mac_txq_init(sta->txq[i]);
Michal Kazior76f90022014-02-25 09:29:57 +02005715 }
5716
Michal Kazior9797feb2014-02-14 14:49:48 +01005717 /* cancel must be done outside the mutex to avoid deadlock */
5718 if ((old_state == IEEE80211_STA_NONE &&
5719 new_state == IEEE80211_STA_NOTEXIST))
5720 cancel_work_sync(&arsta->update_wk);
5721
Kalle Valo5e3dd152013-06-12 20:52:10 +03005722 mutex_lock(&ar->conf_mutex);
5723
5724 if (old_state == IEEE80211_STA_NOTEXIST &&
Michal Kazior077efc82014-10-21 10:10:29 +03005725 new_state == IEEE80211_STA_NONE) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03005726 /*
5727 * New station addition.
5728 */
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005729 enum wmi_peer_type peer_type = WMI_PEER_TYPE_DEFAULT;
5730 u32 num_tdls_stations;
5731 u32 num_tdls_vifs;
5732
Michal Kaziorcfd10612014-11-25 15:16:05 +01005733 ath10k_dbg(ar, ATH10K_DBG_MAC,
5734 "mac vdev %d peer create %pM (new sta) sta %d / %d peer %d / %d\n",
5735 arvif->vdev_id, sta->addr,
5736 ar->num_stations + 1, ar->max_num_stations,
5737 ar->num_peers + 1, ar->max_num_peers);
Bartosz Markowski0e759f32014-01-02 14:38:33 +01005738
Marek Puzyniak7c354242015-03-30 09:51:52 +03005739 ret = ath10k_mac_inc_num_stations(arvif, sta);
Michal Kaziorcfd10612014-11-25 15:16:05 +01005740 if (ret) {
5741 ath10k_warn(ar, "refusing to associate station: too many connected already (%d)\n",
5742 ar->max_num_stations);
Bartosz Markowski0e759f32014-01-02 14:38:33 +01005743 goto exit;
5744 }
5745
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005746 if (sta->tdls)
5747 peer_type = WMI_PEER_TYPE_TDLS;
5748
Michal Kazior69427262016-03-06 16:14:30 +02005749 ret = ath10k_peer_create(ar, vif, sta, arvif->vdev_id,
5750 sta->addr, peer_type);
Michal Kaziora52c0282014-11-25 15:16:03 +01005751 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005752 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 -08005753 sta->addr, arvif->vdev_id, ret);
Marek Puzyniak7c354242015-03-30 09:51:52 +03005754 ath10k_mac_dec_num_stations(arvif, sta);
Michal Kaziora52c0282014-11-25 15:16:03 +01005755 goto exit;
5756 }
Michal Kazior077efc82014-10-21 10:10:29 +03005757
Michal Kaziorbb8f0c62016-03-06 16:14:27 +02005758 spin_lock_bh(&ar->data_lock);
5759
5760 peer = ath10k_peer_find(ar, arvif->vdev_id, sta->addr);
5761 if (!peer) {
5762 ath10k_warn(ar, "failed to lookup peer %pM on vdev %i\n",
5763 vif->addr, arvif->vdev_id);
5764 spin_unlock_bh(&ar->data_lock);
5765 ath10k_peer_delete(ar, arvif->vdev_id, sta->addr);
5766 ath10k_mac_dec_num_stations(arvif, sta);
5767 ret = -ENOENT;
5768 goto exit;
5769 }
5770
5771 arsta->peer_id = find_first_bit(peer->peer_ids,
5772 ATH10K_MAX_NUM_PEER_IDS);
5773
5774 spin_unlock_bh(&ar->data_lock);
5775
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005776 if (!sta->tdls)
5777 goto exit;
Michal Kazior077efc82014-10-21 10:10:29 +03005778
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005779 num_tdls_stations = ath10k_mac_tdls_vif_stations_count(hw, vif);
5780 num_tdls_vifs = ath10k_mac_tdls_vifs_count(hw);
5781
5782 if (num_tdls_vifs >= ar->max_num_tdls_vdevs &&
5783 num_tdls_stations == 0) {
5784 ath10k_warn(ar, "vdev %i exceeded maximum number of tdls vdevs %i\n",
5785 arvif->vdev_id, ar->max_num_tdls_vdevs);
5786 ath10k_peer_delete(ar, arvif->vdev_id, sta->addr);
5787 ath10k_mac_dec_num_stations(arvif, sta);
5788 ret = -ENOBUFS;
5789 goto exit;
5790 }
5791
5792 if (num_tdls_stations == 0) {
5793 /* This is the first tdls peer in current vif */
5794 enum wmi_tdls_state state = WMI_TDLS_ENABLE_ACTIVE;
5795
5796 ret = ath10k_wmi_update_fw_tdls_state(ar, arvif->vdev_id,
5797 state);
Michal Kazior077efc82014-10-21 10:10:29 +03005798 if (ret) {
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005799 ath10k_warn(ar, "failed to update fw tdls state on vdev %i: %i\n",
Michal Kazior077efc82014-10-21 10:10:29 +03005800 arvif->vdev_id, ret);
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005801 ath10k_peer_delete(ar, arvif->vdev_id,
5802 sta->addr);
5803 ath10k_mac_dec_num_stations(arvif, sta);
Michal Kazior077efc82014-10-21 10:10:29 +03005804 goto exit;
5805 }
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005806 }
Michal Kazior077efc82014-10-21 10:10:29 +03005807
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005808 ret = ath10k_mac_tdls_peer_update(ar, arvif->vdev_id, sta,
5809 WMI_TDLS_PEER_STATE_PEERING);
5810 if (ret) {
5811 ath10k_warn(ar,
5812 "failed to update tdls peer %pM for vdev %d when adding a new sta: %i\n",
5813 sta->addr, arvif->vdev_id, ret);
5814 ath10k_peer_delete(ar, arvif->vdev_id, sta->addr);
5815 ath10k_mac_dec_num_stations(arvif, sta);
5816
5817 if (num_tdls_stations != 0)
5818 goto exit;
5819 ath10k_wmi_update_fw_tdls_state(ar, arvif->vdev_id,
5820 WMI_TDLS_DISABLE);
Michal Kazior077efc82014-10-21 10:10:29 +03005821 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03005822 } else if ((old_state == IEEE80211_STA_NONE &&
5823 new_state == IEEE80211_STA_NOTEXIST)) {
5824 /*
5825 * Existing station deletion.
5826 */
Michal Kazior7aa7a722014-08-25 12:09:38 +02005827 ath10k_dbg(ar, ATH10K_DBG_MAC,
Kalle Valo60c3daa2013-09-08 17:56:07 +03005828 "mac vdev %d peer delete %pM (sta gone)\n",
5829 arvif->vdev_id, sta->addr);
Michal Kazior077efc82014-10-21 10:10:29 +03005830
Kalle Valo5e3dd152013-06-12 20:52:10 +03005831 ret = ath10k_peer_delete(ar, arvif->vdev_id, sta->addr);
5832 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005833 ath10k_warn(ar, "failed to delete peer %pM for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02005834 sta->addr, arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005835
Marek Puzyniak7c354242015-03-30 09:51:52 +03005836 ath10k_mac_dec_num_stations(arvif, sta);
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005837
Michal Kazior69427262016-03-06 16:14:30 +02005838 spin_lock_bh(&ar->data_lock);
5839 for (i = 0; i < ARRAY_SIZE(ar->peer_map); i++) {
5840 peer = ar->peer_map[i];
5841 if (!peer)
5842 continue;
5843
5844 if (peer->sta == sta) {
5845 ath10k_warn(ar, "found sta peer %pM entry on vdev %i after it was supposedly removed\n",
5846 sta->addr, arvif->vdev_id);
5847 peer->sta = NULL;
5848 }
5849 }
5850 spin_unlock_bh(&ar->data_lock);
5851
Michal Kazior29946872016-03-06 16:14:34 +02005852 for (i = 0; i < ARRAY_SIZE(sta->txq); i++)
5853 ath10k_mac_txq_unref(ar, sta->txq[i]);
5854
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005855 if (!sta->tdls)
5856 goto exit;
5857
5858 if (ath10k_mac_tdls_vif_stations_count(hw, vif))
5859 goto exit;
5860
5861 /* This was the last tdls peer in current vif */
5862 ret = ath10k_wmi_update_fw_tdls_state(ar, arvif->vdev_id,
5863 WMI_TDLS_DISABLE);
5864 if (ret) {
5865 ath10k_warn(ar, "failed to update fw tdls state on vdev %i: %i\n",
5866 arvif->vdev_id, ret);
5867 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03005868 } else if (old_state == IEEE80211_STA_AUTH &&
5869 new_state == IEEE80211_STA_ASSOC &&
5870 (vif->type == NL80211_IFTYPE_AP ||
Bob Copelandb6c7baf2015-09-09 12:47:36 -04005871 vif->type == NL80211_IFTYPE_MESH_POINT ||
Kalle Valo5e3dd152013-06-12 20:52:10 +03005872 vif->type == NL80211_IFTYPE_ADHOC)) {
5873 /*
5874 * New association.
5875 */
Michal Kazior7aa7a722014-08-25 12:09:38 +02005876 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac sta %pM associated\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03005877 sta->addr);
5878
Michal Kazior590922a2014-10-21 10:10:29 +03005879 ret = ath10k_station_assoc(ar, vif, sta, false);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005880 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005881 ath10k_warn(ar, "failed to associate station %pM for vdev %i: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02005882 sta->addr, arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005883 } else if (old_state == IEEE80211_STA_ASSOC &&
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005884 new_state == IEEE80211_STA_AUTHORIZED &&
5885 sta->tdls) {
5886 /*
5887 * Tdls station authorized.
5888 */
5889 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac tdls sta %pM authorized\n",
5890 sta->addr);
5891
5892 ret = ath10k_station_assoc(ar, vif, sta, false);
5893 if (ret) {
5894 ath10k_warn(ar, "failed to associate tdls station %pM for vdev %i: %i\n",
5895 sta->addr, arvif->vdev_id, ret);
5896 goto exit;
5897 }
5898
5899 ret = ath10k_mac_tdls_peer_update(ar, arvif->vdev_id, sta,
5900 WMI_TDLS_PEER_STATE_CONNECTED);
5901 if (ret)
5902 ath10k_warn(ar, "failed to update tdls peer %pM for vdev %i: %i\n",
5903 sta->addr, arvif->vdev_id, ret);
5904 } else if (old_state == IEEE80211_STA_ASSOC &&
5905 new_state == IEEE80211_STA_AUTH &&
5906 (vif->type == NL80211_IFTYPE_AP ||
Bob Copelandb6c7baf2015-09-09 12:47:36 -04005907 vif->type == NL80211_IFTYPE_MESH_POINT ||
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005908 vif->type == NL80211_IFTYPE_ADHOC)) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03005909 /*
5910 * Disassociation.
5911 */
Michal Kazior7aa7a722014-08-25 12:09:38 +02005912 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac sta %pM disassociated\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03005913 sta->addr);
5914
Michal Kazior590922a2014-10-21 10:10:29 +03005915 ret = ath10k_station_disassoc(ar, vif, sta);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005916 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005917 ath10k_warn(ar, "failed to disassociate station: %pM vdev %i: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02005918 sta->addr, arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005919 }
Bartosz Markowski0e759f32014-01-02 14:38:33 +01005920exit:
Kalle Valo5e3dd152013-06-12 20:52:10 +03005921 mutex_unlock(&ar->conf_mutex);
5922 return ret;
5923}
5924
5925static int ath10k_conf_tx_uapsd(struct ath10k *ar, struct ieee80211_vif *vif,
Kalle Valo5b07e072014-09-14 12:50:06 +03005926 u16 ac, bool enable)
Kalle Valo5e3dd152013-06-12 20:52:10 +03005927{
5928 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kaziorb0e56152015-01-24 12:14:52 +02005929 struct wmi_sta_uapsd_auto_trig_arg arg = {};
5930 u32 prio = 0, acc = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005931 u32 value = 0;
5932 int ret = 0;
5933
Michal Kazior548db542013-07-05 16:15:15 +03005934 lockdep_assert_held(&ar->conf_mutex);
5935
Kalle Valo5e3dd152013-06-12 20:52:10 +03005936 if (arvif->vdev_type != WMI_VDEV_TYPE_STA)
5937 return 0;
5938
5939 switch (ac) {
5940 case IEEE80211_AC_VO:
5941 value = WMI_STA_PS_UAPSD_AC3_DELIVERY_EN |
5942 WMI_STA_PS_UAPSD_AC3_TRIGGER_EN;
Michal Kaziorb0e56152015-01-24 12:14:52 +02005943 prio = 7;
5944 acc = 3;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005945 break;
5946 case IEEE80211_AC_VI:
5947 value = WMI_STA_PS_UAPSD_AC2_DELIVERY_EN |
5948 WMI_STA_PS_UAPSD_AC2_TRIGGER_EN;
Michal Kaziorb0e56152015-01-24 12:14:52 +02005949 prio = 5;
5950 acc = 2;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005951 break;
5952 case IEEE80211_AC_BE:
5953 value = WMI_STA_PS_UAPSD_AC1_DELIVERY_EN |
5954 WMI_STA_PS_UAPSD_AC1_TRIGGER_EN;
Michal Kaziorb0e56152015-01-24 12:14:52 +02005955 prio = 2;
5956 acc = 1;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005957 break;
5958 case IEEE80211_AC_BK:
5959 value = WMI_STA_PS_UAPSD_AC0_DELIVERY_EN |
5960 WMI_STA_PS_UAPSD_AC0_TRIGGER_EN;
Michal Kaziorb0e56152015-01-24 12:14:52 +02005961 prio = 0;
5962 acc = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005963 break;
5964 }
5965
5966 if (enable)
5967 arvif->u.sta.uapsd |= value;
5968 else
5969 arvif->u.sta.uapsd &= ~value;
5970
5971 ret = ath10k_wmi_set_sta_ps_param(ar, arvif->vdev_id,
5972 WMI_STA_PS_PARAM_UAPSD,
5973 arvif->u.sta.uapsd);
5974 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005975 ath10k_warn(ar, "failed to set uapsd params: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005976 goto exit;
5977 }
5978
5979 if (arvif->u.sta.uapsd)
5980 value = WMI_STA_PS_RX_WAKE_POLICY_POLL_UAPSD;
5981 else
5982 value = WMI_STA_PS_RX_WAKE_POLICY_WAKE;
5983
5984 ret = ath10k_wmi_set_sta_ps_param(ar, arvif->vdev_id,
5985 WMI_STA_PS_PARAM_RX_WAKE_POLICY,
5986 value);
5987 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005988 ath10k_warn(ar, "failed to set rx wake param: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005989
Michal Kazior9f9b5742014-12-12 12:41:36 +01005990 ret = ath10k_mac_vif_recalc_ps_wake_threshold(arvif);
5991 if (ret) {
5992 ath10k_warn(ar, "failed to recalc ps wake threshold on vdev %i: %d\n",
5993 arvif->vdev_id, ret);
5994 return ret;
5995 }
5996
5997 ret = ath10k_mac_vif_recalc_ps_poll_count(arvif);
5998 if (ret) {
5999 ath10k_warn(ar, "failed to recalc ps poll count on vdev %i: %d\n",
6000 arvif->vdev_id, ret);
6001 return ret;
6002 }
6003
Michal Kaziorb0e56152015-01-24 12:14:52 +02006004 if (test_bit(WMI_SERVICE_STA_UAPSD_BASIC_AUTO_TRIG, ar->wmi.svc_map) ||
6005 test_bit(WMI_SERVICE_STA_UAPSD_VAR_AUTO_TRIG, ar->wmi.svc_map)) {
6006 /* Only userspace can make an educated decision when to send
6007 * trigger frame. The following effectively disables u-UAPSD
6008 * autotrigger in firmware (which is enabled by default
6009 * provided the autotrigger service is available).
6010 */
6011
6012 arg.wmm_ac = acc;
6013 arg.user_priority = prio;
6014 arg.service_interval = 0;
6015 arg.suspend_interval = WMI_STA_UAPSD_MAX_INTERVAL_MSEC;
6016 arg.delay_interval = WMI_STA_UAPSD_MAX_INTERVAL_MSEC;
6017
6018 ret = ath10k_wmi_vdev_sta_uapsd(ar, arvif->vdev_id,
6019 arvif->bssid, &arg, 1);
6020 if (ret) {
6021 ath10k_warn(ar, "failed to set uapsd auto trigger %d\n",
6022 ret);
6023 return ret;
6024 }
6025 }
6026
Kalle Valo5e3dd152013-06-12 20:52:10 +03006027exit:
6028 return ret;
6029}
6030
6031static int ath10k_conf_tx(struct ieee80211_hw *hw,
6032 struct ieee80211_vif *vif, u16 ac,
6033 const struct ieee80211_tx_queue_params *params)
6034{
6035 struct ath10k *ar = hw->priv;
Michal Kazior5e752e42015-01-19 09:53:41 +01006036 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Kalle Valo5e3dd152013-06-12 20:52:10 +03006037 struct wmi_wmm_params_arg *p = NULL;
6038 int ret;
6039
6040 mutex_lock(&ar->conf_mutex);
6041
6042 switch (ac) {
6043 case IEEE80211_AC_VO:
Michal Kazior5e752e42015-01-19 09:53:41 +01006044 p = &arvif->wmm_params.ac_vo;
Kalle Valo5e3dd152013-06-12 20:52:10 +03006045 break;
6046 case IEEE80211_AC_VI:
Michal Kazior5e752e42015-01-19 09:53:41 +01006047 p = &arvif->wmm_params.ac_vi;
Kalle Valo5e3dd152013-06-12 20:52:10 +03006048 break;
6049 case IEEE80211_AC_BE:
Michal Kazior5e752e42015-01-19 09:53:41 +01006050 p = &arvif->wmm_params.ac_be;
Kalle Valo5e3dd152013-06-12 20:52:10 +03006051 break;
6052 case IEEE80211_AC_BK:
Michal Kazior5e752e42015-01-19 09:53:41 +01006053 p = &arvif->wmm_params.ac_bk;
Kalle Valo5e3dd152013-06-12 20:52:10 +03006054 break;
6055 }
6056
6057 if (WARN_ON(!p)) {
6058 ret = -EINVAL;
6059 goto exit;
6060 }
6061
6062 p->cwmin = params->cw_min;
6063 p->cwmax = params->cw_max;
6064 p->aifs = params->aifs;
6065
6066 /*
6067 * The channel time duration programmed in the HW is in absolute
6068 * microseconds, while mac80211 gives the txop in units of
6069 * 32 microseconds.
6070 */
6071 p->txop = params->txop * 32;
6072
Michal Kazior7fc979a2015-01-28 09:57:28 +02006073 if (ar->wmi.ops->gen_vdev_wmm_conf) {
6074 ret = ath10k_wmi_vdev_wmm_conf(ar, arvif->vdev_id,
6075 &arvif->wmm_params);
6076 if (ret) {
6077 ath10k_warn(ar, "failed to set vdev wmm params on vdev %i: %d\n",
6078 arvif->vdev_id, ret);
6079 goto exit;
6080 }
6081 } else {
6082 /* This won't work well with multi-interface cases but it's
6083 * better than nothing.
6084 */
6085 ret = ath10k_wmi_pdev_set_wmm_params(ar, &arvif->wmm_params);
6086 if (ret) {
6087 ath10k_warn(ar, "failed to set wmm params: %d\n", ret);
6088 goto exit;
6089 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03006090 }
6091
6092 ret = ath10k_conf_tx_uapsd(ar, vif, ac, params->uapsd);
6093 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02006094 ath10k_warn(ar, "failed to set sta uapsd: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03006095
6096exit:
6097 mutex_unlock(&ar->conf_mutex);
6098 return ret;
6099}
6100
6101#define ATH10K_ROC_TIMEOUT_HZ (2*HZ)
6102
6103static int ath10k_remain_on_channel(struct ieee80211_hw *hw,
6104 struct ieee80211_vif *vif,
6105 struct ieee80211_channel *chan,
6106 int duration,
6107 enum ieee80211_roc_type type)
6108{
6109 struct ath10k *ar = hw->priv;
6110 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
6111 struct wmi_start_scan_arg arg;
Michal Kazior5c81c7f2014-08-05 14:54:44 +02006112 int ret = 0;
Michal Kaziorfcf98442015-03-31 11:03:47 +00006113 u32 scan_time_msec;
Kalle Valo5e3dd152013-06-12 20:52:10 +03006114
6115 mutex_lock(&ar->conf_mutex);
6116
6117 spin_lock_bh(&ar->data_lock);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02006118 switch (ar->scan.state) {
6119 case ATH10K_SCAN_IDLE:
6120 reinit_completion(&ar->scan.started);
6121 reinit_completion(&ar->scan.completed);
6122 reinit_completion(&ar->scan.on_channel);
6123 ar->scan.state = ATH10K_SCAN_STARTING;
6124 ar->scan.is_roc = true;
6125 ar->scan.vdev_id = arvif->vdev_id;
6126 ar->scan.roc_freq = chan->center_freq;
Michal Kaziord710e752015-07-09 13:08:36 +02006127 ar->scan.roc_notify = true;
Michal Kazior5c81c7f2014-08-05 14:54:44 +02006128 ret = 0;
6129 break;
6130 case ATH10K_SCAN_STARTING:
6131 case ATH10K_SCAN_RUNNING:
6132 case ATH10K_SCAN_ABORTING:
Kalle Valo5e3dd152013-06-12 20:52:10 +03006133 ret = -EBUSY;
Michal Kazior5c81c7f2014-08-05 14:54:44 +02006134 break;
Kalle Valo5e3dd152013-06-12 20:52:10 +03006135 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03006136 spin_unlock_bh(&ar->data_lock);
6137
Michal Kazior5c81c7f2014-08-05 14:54:44 +02006138 if (ret)
6139 goto exit;
6140
Michal Kaziorfcf98442015-03-31 11:03:47 +00006141 scan_time_msec = ar->hw->wiphy->max_remain_on_channel_duration * 2;
Michal Kaziordcca0bd2014-11-24 14:58:32 +01006142
Kalle Valo5e3dd152013-06-12 20:52:10 +03006143 memset(&arg, 0, sizeof(arg));
6144 ath10k_wmi_start_scan_init(ar, &arg);
6145 arg.vdev_id = arvif->vdev_id;
6146 arg.scan_id = ATH10K_SCAN_ID;
6147 arg.n_channels = 1;
6148 arg.channels[0] = chan->center_freq;
Michal Kaziorfcf98442015-03-31 11:03:47 +00006149 arg.dwell_time_active = scan_time_msec;
6150 arg.dwell_time_passive = scan_time_msec;
6151 arg.max_scan_time = scan_time_msec;
Kalle Valo5e3dd152013-06-12 20:52:10 +03006152 arg.scan_ctrl_flags |= WMI_SCAN_FLAG_PASSIVE;
6153 arg.scan_ctrl_flags |= WMI_SCAN_FILTER_PROBE_REQ;
Michal Kaziordbd3f9f2015-03-31 11:03:48 +00006154 arg.burst_duration_ms = duration;
Kalle Valo5e3dd152013-06-12 20:52:10 +03006155
6156 ret = ath10k_start_scan(ar, &arg);
6157 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02006158 ath10k_warn(ar, "failed to start roc scan: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03006159 spin_lock_bh(&ar->data_lock);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02006160 ar->scan.state = ATH10K_SCAN_IDLE;
Kalle Valo5e3dd152013-06-12 20:52:10 +03006161 spin_unlock_bh(&ar->data_lock);
6162 goto exit;
6163 }
6164
6165 ret = wait_for_completion_timeout(&ar->scan.on_channel, 3*HZ);
6166 if (ret == 0) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02006167 ath10k_warn(ar, "failed to switch to channel for roc scan\n");
Michal Kazior5c81c7f2014-08-05 14:54:44 +02006168
6169 ret = ath10k_scan_stop(ar);
6170 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02006171 ath10k_warn(ar, "failed to stop scan: %d\n", ret);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02006172
Kalle Valo5e3dd152013-06-12 20:52:10 +03006173 ret = -ETIMEDOUT;
6174 goto exit;
6175 }
6176
Michal Kaziorfcf98442015-03-31 11:03:47 +00006177 ieee80211_queue_delayed_work(ar->hw, &ar->scan.timeout,
6178 msecs_to_jiffies(duration));
6179
Kalle Valo5e3dd152013-06-12 20:52:10 +03006180 ret = 0;
6181exit:
6182 mutex_unlock(&ar->conf_mutex);
6183 return ret;
6184}
6185
6186static int ath10k_cancel_remain_on_channel(struct ieee80211_hw *hw)
6187{
6188 struct ath10k *ar = hw->priv;
6189
6190 mutex_lock(&ar->conf_mutex);
Michal Kaziord710e752015-07-09 13:08:36 +02006191
6192 spin_lock_bh(&ar->data_lock);
6193 ar->scan.roc_notify = false;
6194 spin_unlock_bh(&ar->data_lock);
6195
Michal Kazior5c81c7f2014-08-05 14:54:44 +02006196 ath10k_scan_abort(ar);
Michal Kaziord710e752015-07-09 13:08:36 +02006197
Kalle Valo5e3dd152013-06-12 20:52:10 +03006198 mutex_unlock(&ar->conf_mutex);
6199
Michal Kazior4eb2e162014-10-28 10:23:09 +01006200 cancel_delayed_work_sync(&ar->scan.timeout);
6201
Kalle Valo5e3dd152013-06-12 20:52:10 +03006202 return 0;
6203}
6204
6205/*
6206 * Both RTS and Fragmentation threshold are interface-specific
6207 * in ath10k, but device-specific in mac80211.
6208 */
Kalle Valo5e3dd152013-06-12 20:52:10 +03006209
6210static int ath10k_set_rts_threshold(struct ieee80211_hw *hw, u32 value)
6211{
Kalle Valo5e3dd152013-06-12 20:52:10 +03006212 struct ath10k *ar = hw->priv;
Michal Kaziorad088bf2013-10-16 15:44:46 +03006213 struct ath10k_vif *arvif;
6214 int ret = 0;
Michal Kazior548db542013-07-05 16:15:15 +03006215
Michal Kaziorad088bf2013-10-16 15:44:46 +03006216 mutex_lock(&ar->conf_mutex);
6217 list_for_each_entry(arvif, &ar->arvifs, list) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02006218 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %d rts threshold %d\n",
Michal Kaziorad088bf2013-10-16 15:44:46 +03006219 arvif->vdev_id, value);
Kalle Valo60c3daa2013-09-08 17:56:07 +03006220
Michal Kaziorad088bf2013-10-16 15:44:46 +03006221 ret = ath10k_mac_set_rts(arvif, value);
6222 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02006223 ath10k_warn(ar, "failed to set rts threshold for vdev %d: %d\n",
Michal Kaziorad088bf2013-10-16 15:44:46 +03006224 arvif->vdev_id, ret);
6225 break;
6226 }
6227 }
6228 mutex_unlock(&ar->conf_mutex);
6229
6230 return ret;
Kalle Valo5e3dd152013-06-12 20:52:10 +03006231}
6232
Michal Kazior92092fe2015-08-03 11:16:43 +02006233static int ath10k_mac_op_set_frag_threshold(struct ieee80211_hw *hw, u32 value)
6234{
6235 /* Even though there's a WMI enum for fragmentation threshold no known
6236 * firmware actually implements it. Moreover it is not possible to rely
6237 * frame fragmentation to mac80211 because firmware clears the "more
6238 * fragments" bit in frame control making it impossible for remote
6239 * devices to reassemble frames.
6240 *
6241 * Hence implement a dummy callback just to say fragmentation isn't
6242 * supported. This effectively prevents mac80211 from doing frame
6243 * fragmentation in software.
6244 */
6245 return -EOPNOTSUPP;
6246}
6247
Emmanuel Grumbach77be2c52014-03-27 11:30:29 +02006248static void ath10k_flush(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
6249 u32 queues, bool drop)
Kalle Valo5e3dd152013-06-12 20:52:10 +03006250{
6251 struct ath10k *ar = hw->priv;
Michal Kazioraffd3212013-07-16 09:54:35 +02006252 bool skip;
Nicholas Mc Guired4298a32015-06-15 14:46:43 +03006253 long time_left;
Kalle Valo5e3dd152013-06-12 20:52:10 +03006254
6255 /* mac80211 doesn't care if we really xmit queued frames or not
6256 * we'll collect those frames either way if we stop/delete vdevs */
6257 if (drop)
6258 return;
6259
Michal Kazior548db542013-07-05 16:15:15 +03006260 mutex_lock(&ar->conf_mutex);
6261
Michal Kazioraffd3212013-07-16 09:54:35 +02006262 if (ar->state == ATH10K_STATE_WEDGED)
6263 goto skip;
6264
Nicholas Mc Guired4298a32015-06-15 14:46:43 +03006265 time_left = wait_event_timeout(ar->htt.empty_tx_wq, ({
Kalle Valo5e3dd152013-06-12 20:52:10 +03006266 bool empty;
Michal Kazioraffd3212013-07-16 09:54:35 +02006267
Michal Kazioredb82362013-07-05 16:15:14 +03006268 spin_lock_bh(&ar->htt.tx_lock);
Michal Kazior0945baf2013-09-18 14:43:18 +02006269 empty = (ar->htt.num_pending_tx == 0);
Michal Kazioredb82362013-07-05 16:15:14 +03006270 spin_unlock_bh(&ar->htt.tx_lock);
Michal Kazioraffd3212013-07-16 09:54:35 +02006271
Michal Kazior7962b0d2014-10-28 10:34:38 +01006272 skip = (ar->state == ATH10K_STATE_WEDGED) ||
6273 test_bit(ATH10K_FLAG_CRASH_FLUSH,
6274 &ar->dev_flags);
Michal Kazioraffd3212013-07-16 09:54:35 +02006275
6276 (empty || skip);
Kalle Valo5e3dd152013-06-12 20:52:10 +03006277 }), ATH10K_FLUSH_TIMEOUT_HZ);
Michal Kazioraffd3212013-07-16 09:54:35 +02006278
Nicholas Mc Guired4298a32015-06-15 14:46:43 +03006279 if (time_left == 0 || skip)
6280 ath10k_warn(ar, "failed to flush transmit queue (skip %i ar-state %i): %ld\n",
6281 skip, ar->state, time_left);
Michal Kazior548db542013-07-05 16:15:15 +03006282
Michal Kazioraffd3212013-07-16 09:54:35 +02006283skip:
Michal Kazior548db542013-07-05 16:15:15 +03006284 mutex_unlock(&ar->conf_mutex);
Kalle Valo5e3dd152013-06-12 20:52:10 +03006285}
6286
6287/* TODO: Implement this function properly
6288 * For now it is needed to reply to Probe Requests in IBSS mode.
6289 * Propably we need this information from FW.
6290 */
6291static int ath10k_tx_last_beacon(struct ieee80211_hw *hw)
6292{
6293 return 1;
6294}
6295
Eliad Pellercf2c92d2014-11-04 11:43:54 +02006296static void ath10k_reconfig_complete(struct ieee80211_hw *hw,
6297 enum ieee80211_reconfig_type reconfig_type)
Michal Kazioraffd3212013-07-16 09:54:35 +02006298{
6299 struct ath10k *ar = hw->priv;
6300
Eliad Pellercf2c92d2014-11-04 11:43:54 +02006301 if (reconfig_type != IEEE80211_RECONFIG_TYPE_RESTART)
6302 return;
6303
Michal Kazioraffd3212013-07-16 09:54:35 +02006304 mutex_lock(&ar->conf_mutex);
6305
6306 /* If device failed to restart it will be in a different state, e.g.
6307 * ATH10K_STATE_WEDGED */
6308 if (ar->state == ATH10K_STATE_RESTARTED) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02006309 ath10k_info(ar, "device successfully recovered\n");
Michal Kazioraffd3212013-07-16 09:54:35 +02006310 ar->state = ATH10K_STATE_ON;
Michal Kazior7962b0d2014-10-28 10:34:38 +01006311 ieee80211_wake_queues(ar->hw);
Michal Kazioraffd3212013-07-16 09:54:35 +02006312 }
6313
6314 mutex_unlock(&ar->conf_mutex);
6315}
6316
Michal Kazior2e1dea42013-07-31 10:32:40 +02006317static int ath10k_get_survey(struct ieee80211_hw *hw, int idx,
6318 struct survey_info *survey)
6319{
6320 struct ath10k *ar = hw->priv;
6321 struct ieee80211_supported_band *sband;
6322 struct survey_info *ar_survey = &ar->survey[idx];
6323 int ret = 0;
6324
6325 mutex_lock(&ar->conf_mutex);
6326
6327 sband = hw->wiphy->bands[IEEE80211_BAND_2GHZ];
6328 if (sband && idx >= sband->n_channels) {
6329 idx -= sband->n_channels;
6330 sband = NULL;
6331 }
6332
6333 if (!sband)
6334 sband = hw->wiphy->bands[IEEE80211_BAND_5GHZ];
6335
6336 if (!sband || idx >= sband->n_channels) {
6337 ret = -ENOENT;
6338 goto exit;
6339 }
6340
6341 spin_lock_bh(&ar->data_lock);
6342 memcpy(survey, ar_survey, sizeof(*survey));
6343 spin_unlock_bh(&ar->data_lock);
6344
6345 survey->channel = &sband->channels[idx];
6346
Felix Fietkaufa1d4df2014-10-23 17:04:28 +03006347 if (ar->rx_channel == survey->channel)
6348 survey->filled |= SURVEY_INFO_IN_USE;
6349
Michal Kazior2e1dea42013-07-31 10:32:40 +02006350exit:
6351 mutex_unlock(&ar->conf_mutex);
6352 return ret;
6353}
6354
Michal Kazior3ae54222015-03-31 10:49:20 +00006355static bool
6356ath10k_mac_bitrate_mask_has_single_rate(struct ath10k *ar,
6357 enum ieee80211_band band,
6358 const struct cfg80211_bitrate_mask *mask)
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006359{
Michal Kazior3ae54222015-03-31 10:49:20 +00006360 int num_rates = 0;
6361 int i;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006362
Michal Kazior3ae54222015-03-31 10:49:20 +00006363 num_rates += hweight32(mask->control[band].legacy);
6364
6365 for (i = 0; i < ARRAY_SIZE(mask->control[band].ht_mcs); i++)
6366 num_rates += hweight8(mask->control[band].ht_mcs[i]);
6367
6368 for (i = 0; i < ARRAY_SIZE(mask->control[band].vht_mcs); i++)
6369 num_rates += hweight16(mask->control[band].vht_mcs[i]);
6370
6371 return num_rates == 1;
6372}
6373
6374static bool
6375ath10k_mac_bitrate_mask_get_single_nss(struct ath10k *ar,
6376 enum ieee80211_band band,
6377 const struct cfg80211_bitrate_mask *mask,
6378 int *nss)
6379{
6380 struct ieee80211_supported_band *sband = &ar->mac.sbands[band];
6381 u16 vht_mcs_map = le16_to_cpu(sband->vht_cap.vht_mcs.tx_mcs_map);
6382 u8 ht_nss_mask = 0;
6383 u8 vht_nss_mask = 0;
6384 int i;
6385
6386 if (mask->control[band].legacy)
6387 return false;
6388
6389 for (i = 0; i < ARRAY_SIZE(mask->control[band].ht_mcs); i++) {
6390 if (mask->control[band].ht_mcs[i] == 0)
6391 continue;
6392 else if (mask->control[band].ht_mcs[i] ==
6393 sband->ht_cap.mcs.rx_mask[i])
6394 ht_nss_mask |= BIT(i);
6395 else
6396 return false;
6397 }
6398
6399 for (i = 0; i < ARRAY_SIZE(mask->control[band].vht_mcs); i++) {
6400 if (mask->control[band].vht_mcs[i] == 0)
6401 continue;
6402 else if (mask->control[band].vht_mcs[i] ==
6403 ath10k_mac_get_max_vht_mcs_map(vht_mcs_map, i))
6404 vht_nss_mask |= BIT(i);
6405 else
6406 return false;
6407 }
6408
6409 if (ht_nss_mask != vht_nss_mask)
6410 return false;
6411
6412 if (ht_nss_mask == 0)
6413 return false;
6414
6415 if (BIT(fls(ht_nss_mask)) - 1 != ht_nss_mask)
6416 return false;
6417
6418 *nss = fls(ht_nss_mask);
6419
6420 return true;
6421}
6422
6423static int
6424ath10k_mac_bitrate_mask_get_single_rate(struct ath10k *ar,
6425 enum ieee80211_band band,
6426 const struct cfg80211_bitrate_mask *mask,
6427 u8 *rate, u8 *nss)
6428{
6429 struct ieee80211_supported_band *sband = &ar->mac.sbands[band];
6430 int rate_idx;
6431 int i;
6432 u16 bitrate;
6433 u8 preamble;
6434 u8 hw_rate;
6435
6436 if (hweight32(mask->control[band].legacy) == 1) {
6437 rate_idx = ffs(mask->control[band].legacy) - 1;
6438
6439 hw_rate = sband->bitrates[rate_idx].hw_value;
6440 bitrate = sband->bitrates[rate_idx].bitrate;
6441
6442 if (ath10k_mac_bitrate_is_cck(bitrate))
6443 preamble = WMI_RATE_PREAMBLE_CCK;
6444 else
6445 preamble = WMI_RATE_PREAMBLE_OFDM;
6446
6447 *nss = 1;
6448 *rate = preamble << 6 |
6449 (*nss - 1) << 4 |
6450 hw_rate << 0;
6451
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006452 return 0;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006453 }
6454
Michal Kazior3ae54222015-03-31 10:49:20 +00006455 for (i = 0; i < ARRAY_SIZE(mask->control[band].ht_mcs); i++) {
6456 if (hweight8(mask->control[band].ht_mcs[i]) == 1) {
6457 *nss = i + 1;
6458 *rate = WMI_RATE_PREAMBLE_HT << 6 |
6459 (*nss - 1) << 4 |
6460 (ffs(mask->control[band].ht_mcs[i]) - 1);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006461
Michal Kazior3ae54222015-03-31 10:49:20 +00006462 return 0;
6463 }
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006464 }
6465
Michal Kazior3ae54222015-03-31 10:49:20 +00006466 for (i = 0; i < ARRAY_SIZE(mask->control[band].vht_mcs); i++) {
6467 if (hweight16(mask->control[band].vht_mcs[i]) == 1) {
6468 *nss = i + 1;
6469 *rate = WMI_RATE_PREAMBLE_VHT << 6 |
6470 (*nss - 1) << 4 |
6471 (ffs(mask->control[band].vht_mcs[i]) - 1);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006472
Michal Kazior3ae54222015-03-31 10:49:20 +00006473 return 0;
6474 }
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006475 }
6476
Michal Kazior3ae54222015-03-31 10:49:20 +00006477 return -EINVAL;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006478}
6479
Michal Kazior3ae54222015-03-31 10:49:20 +00006480static int ath10k_mac_set_fixed_rate_params(struct ath10k_vif *arvif,
Rajkumar Manoharanbd4a41e2015-09-16 13:19:00 +05306481 u8 rate, u8 nss, u8 sgi, u8 ldpc)
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006482{
6483 struct ath10k *ar = arvif->ar;
6484 u32 vdev_param;
Michal Kazior3ae54222015-03-31 10:49:20 +00006485 int ret;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006486
Michal Kazior3ae54222015-03-31 10:49:20 +00006487 lockdep_assert_held(&ar->conf_mutex);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006488
Michal Kazior3ae54222015-03-31 10:49:20 +00006489 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac set fixed rate params vdev %i rate 0x%02hhx nss %hhu sgi %hhu\n",
6490 arvif->vdev_id, rate, nss, sgi);
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01006491
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006492 vdev_param = ar->wmi.vdev_param->fixed_rate;
Michal Kazior3ae54222015-03-31 10:49:20 +00006493 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param, rate);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006494 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02006495 ath10k_warn(ar, "failed to set fixed rate param 0x%02x: %d\n",
Michal Kazior3ae54222015-03-31 10:49:20 +00006496 rate, ret);
6497 return ret;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006498 }
6499
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006500 vdev_param = ar->wmi.vdev_param->nss;
Michal Kazior3ae54222015-03-31 10:49:20 +00006501 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param, nss);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006502 if (ret) {
Michal Kazior3ae54222015-03-31 10:49:20 +00006503 ath10k_warn(ar, "failed to set nss param %d: %d\n", nss, ret);
6504 return ret;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006505 }
6506
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01006507 vdev_param = ar->wmi.vdev_param->sgi;
Michal Kazior3ae54222015-03-31 10:49:20 +00006508 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param, sgi);
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01006509 if (ret) {
Michal Kazior3ae54222015-03-31 10:49:20 +00006510 ath10k_warn(ar, "failed to set sgi param %d: %d\n", sgi, ret);
6511 return ret;
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01006512 }
6513
Rajkumar Manoharanbd4a41e2015-09-16 13:19:00 +05306514 vdev_param = ar->wmi.vdev_param->ldpc;
6515 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param, ldpc);
6516 if (ret) {
6517 ath10k_warn(ar, "failed to set ldpc param %d: %d\n", ldpc, ret);
6518 return ret;
6519 }
6520
Michal Kazior3ae54222015-03-31 10:49:20 +00006521 return 0;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006522}
6523
Michal Kazior45c9abc2015-04-21 20:42:58 +03006524static bool
6525ath10k_mac_can_set_bitrate_mask(struct ath10k *ar,
6526 enum ieee80211_band band,
6527 const struct cfg80211_bitrate_mask *mask)
6528{
6529 int i;
6530 u16 vht_mcs;
6531
6532 /* Due to firmware limitation in WMI_PEER_ASSOC_CMDID it is impossible
6533 * to express all VHT MCS rate masks. Effectively only the following
6534 * ranges can be used: none, 0-7, 0-8 and 0-9.
6535 */
6536 for (i = 0; i < NL80211_VHT_NSS_MAX; i++) {
6537 vht_mcs = mask->control[band].vht_mcs[i];
6538
6539 switch (vht_mcs) {
6540 case 0:
6541 case BIT(8) - 1:
6542 case BIT(9) - 1:
6543 case BIT(10) - 1:
6544 break;
6545 default:
6546 ath10k_warn(ar, "refusing bitrate mask with missing 0-7 VHT MCS rates\n");
6547 return false;
6548 }
6549 }
6550
6551 return true;
6552}
6553
6554static void ath10k_mac_set_bitrate_mask_iter(void *data,
6555 struct ieee80211_sta *sta)
6556{
6557 struct ath10k_vif *arvif = data;
6558 struct ath10k_sta *arsta = (struct ath10k_sta *)sta->drv_priv;
6559 struct ath10k *ar = arvif->ar;
6560
6561 if (arsta->arvif != arvif)
6562 return;
6563
6564 spin_lock_bh(&ar->data_lock);
6565 arsta->changed |= IEEE80211_RC_SUPP_RATES_CHANGED;
6566 spin_unlock_bh(&ar->data_lock);
6567
6568 ieee80211_queue_work(ar->hw, &arsta->update_wk);
6569}
6570
Michal Kazior3ae54222015-03-31 10:49:20 +00006571static int ath10k_mac_op_set_bitrate_mask(struct ieee80211_hw *hw,
6572 struct ieee80211_vif *vif,
6573 const struct cfg80211_bitrate_mask *mask)
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006574{
6575 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kazior500ff9f2015-03-31 10:26:21 +00006576 struct cfg80211_chan_def def;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006577 struct ath10k *ar = arvif->ar;
Michal Kazior500ff9f2015-03-31 10:26:21 +00006578 enum ieee80211_band band;
Michal Kazior45c9abc2015-04-21 20:42:58 +03006579 const u8 *ht_mcs_mask;
6580 const u16 *vht_mcs_mask;
Michal Kazior3ae54222015-03-31 10:49:20 +00006581 u8 rate;
6582 u8 nss;
6583 u8 sgi;
Rajkumar Manoharanbd4a41e2015-09-16 13:19:00 +05306584 u8 ldpc;
Michal Kazior3ae54222015-03-31 10:49:20 +00006585 int single_nss;
6586 int ret;
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01006587
Michal Kazior500ff9f2015-03-31 10:26:21 +00006588 if (ath10k_mac_vif_chan(vif, &def))
6589 return -EPERM;
6590
Michal Kazior500ff9f2015-03-31 10:26:21 +00006591 band = def.chan->band;
Michal Kazior45c9abc2015-04-21 20:42:58 +03006592 ht_mcs_mask = mask->control[band].ht_mcs;
6593 vht_mcs_mask = mask->control[band].vht_mcs;
Rajkumar Manoharanbd4a41e2015-09-16 13:19:00 +05306594 ldpc = !!(ar->ht_cap_info & WMI_HT_CAP_LDPC);
Michal Kazior500ff9f2015-03-31 10:26:21 +00006595
Michal Kazior3ae54222015-03-31 10:49:20 +00006596 sgi = mask->control[band].gi;
6597 if (sgi == NL80211_TXRATE_FORCE_LGI)
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01006598 return -EINVAL;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006599
Michal Kazior3ae54222015-03-31 10:49:20 +00006600 if (ath10k_mac_bitrate_mask_has_single_rate(ar, band, mask)) {
6601 ret = ath10k_mac_bitrate_mask_get_single_rate(ar, band, mask,
6602 &rate, &nss);
6603 if (ret) {
6604 ath10k_warn(ar, "failed to get single rate for vdev %i: %d\n",
6605 arvif->vdev_id, ret);
6606 return ret;
6607 }
6608 } else if (ath10k_mac_bitrate_mask_get_single_nss(ar, band, mask,
6609 &single_nss)) {
6610 rate = WMI_FIXED_RATE_NONE;
6611 nss = single_nss;
6612 } else {
6613 rate = WMI_FIXED_RATE_NONE;
Michal Kazior45c9abc2015-04-21 20:42:58 +03006614 nss = min(ar->num_rf_chains,
6615 max(ath10k_mac_max_ht_nss(ht_mcs_mask),
6616 ath10k_mac_max_vht_nss(vht_mcs_mask)));
6617
6618 if (!ath10k_mac_can_set_bitrate_mask(ar, band, mask))
6619 return -EINVAL;
6620
6621 mutex_lock(&ar->conf_mutex);
6622
6623 arvif->bitrate_mask = *mask;
6624 ieee80211_iterate_stations_atomic(ar->hw,
6625 ath10k_mac_set_bitrate_mask_iter,
6626 arvif);
6627
6628 mutex_unlock(&ar->conf_mutex);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006629 }
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006630
6631 mutex_lock(&ar->conf_mutex);
6632
Rajkumar Manoharanbd4a41e2015-09-16 13:19:00 +05306633 ret = ath10k_mac_set_fixed_rate_params(arvif, rate, nss, sgi, ldpc);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006634 if (ret) {
Michal Kazior3ae54222015-03-31 10:49:20 +00006635 ath10k_warn(ar, "failed to set fixed rate params on vdev %i: %d\n",
6636 arvif->vdev_id, ret);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006637 goto exit;
6638 }
6639
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006640exit:
6641 mutex_unlock(&ar->conf_mutex);
Michal Kazior3ae54222015-03-31 10:49:20 +00006642
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006643 return ret;
6644}
6645
Michal Kazior9797feb2014-02-14 14:49:48 +01006646static void ath10k_sta_rc_update(struct ieee80211_hw *hw,
6647 struct ieee80211_vif *vif,
6648 struct ieee80211_sta *sta,
6649 u32 changed)
6650{
6651 struct ath10k *ar = hw->priv;
6652 struct ath10k_sta *arsta = (struct ath10k_sta *)sta->drv_priv;
6653 u32 bw, smps;
6654
6655 spin_lock_bh(&ar->data_lock);
6656
Michal Kazior7aa7a722014-08-25 12:09:38 +02006657 ath10k_dbg(ar, ATH10K_DBG_MAC,
Michal Kazior9797feb2014-02-14 14:49:48 +01006658 "mac sta rc update for %pM changed %08x bw %d nss %d smps %d\n",
6659 sta->addr, changed, sta->bandwidth, sta->rx_nss,
6660 sta->smps_mode);
6661
6662 if (changed & IEEE80211_RC_BW_CHANGED) {
6663 bw = WMI_PEER_CHWIDTH_20MHZ;
6664
6665 switch (sta->bandwidth) {
6666 case IEEE80211_STA_RX_BW_20:
6667 bw = WMI_PEER_CHWIDTH_20MHZ;
6668 break;
6669 case IEEE80211_STA_RX_BW_40:
6670 bw = WMI_PEER_CHWIDTH_40MHZ;
6671 break;
6672 case IEEE80211_STA_RX_BW_80:
6673 bw = WMI_PEER_CHWIDTH_80MHZ;
6674 break;
6675 case IEEE80211_STA_RX_BW_160:
Masanari Iidad939be32015-02-27 23:52:31 +09006676 ath10k_warn(ar, "Invalid bandwidth %d in rc update for %pM\n",
Kalle Valobe6546f2014-03-25 14:18:51 +02006677 sta->bandwidth, sta->addr);
Michal Kazior9797feb2014-02-14 14:49:48 +01006678 bw = WMI_PEER_CHWIDTH_20MHZ;
6679 break;
6680 }
6681
6682 arsta->bw = bw;
6683 }
6684
6685 if (changed & IEEE80211_RC_NSS_CHANGED)
6686 arsta->nss = sta->rx_nss;
6687
6688 if (changed & IEEE80211_RC_SMPS_CHANGED) {
6689 smps = WMI_PEER_SMPS_PS_NONE;
6690
6691 switch (sta->smps_mode) {
6692 case IEEE80211_SMPS_AUTOMATIC:
6693 case IEEE80211_SMPS_OFF:
6694 smps = WMI_PEER_SMPS_PS_NONE;
6695 break;
6696 case IEEE80211_SMPS_STATIC:
6697 smps = WMI_PEER_SMPS_STATIC;
6698 break;
6699 case IEEE80211_SMPS_DYNAMIC:
6700 smps = WMI_PEER_SMPS_DYNAMIC;
6701 break;
6702 case IEEE80211_SMPS_NUM_MODES:
Michal Kazior7aa7a722014-08-25 12:09:38 +02006703 ath10k_warn(ar, "Invalid smps %d in sta rc update for %pM\n",
Kalle Valobe6546f2014-03-25 14:18:51 +02006704 sta->smps_mode, sta->addr);
Michal Kazior9797feb2014-02-14 14:49:48 +01006705 smps = WMI_PEER_SMPS_PS_NONE;
6706 break;
6707 }
6708
6709 arsta->smps = smps;
6710 }
6711
Michal Kazior9797feb2014-02-14 14:49:48 +01006712 arsta->changed |= changed;
6713
6714 spin_unlock_bh(&ar->data_lock);
6715
6716 ieee80211_queue_work(hw, &arsta->update_wk);
6717}
6718
Chun-Yeow Yeoh26ebbcc2014-02-25 09:29:54 +02006719static u64 ath10k_get_tsf(struct ieee80211_hw *hw, struct ieee80211_vif *vif)
6720{
6721 /*
6722 * FIXME: Return 0 for time being. Need to figure out whether FW
6723 * has the API to fetch 64-bit local TSF
6724 */
6725
6726 return 0;
6727}
6728
Michal Kazioraa5b4fb2014-07-23 12:20:33 +02006729static int ath10k_ampdu_action(struct ieee80211_hw *hw,
6730 struct ieee80211_vif *vif,
Sara Sharon50ea05e2015-12-30 16:06:04 +02006731 struct ieee80211_ampdu_params *params)
Michal Kazioraa5b4fb2014-07-23 12:20:33 +02006732{
Michal Kazior7aa7a722014-08-25 12:09:38 +02006733 struct ath10k *ar = hw->priv;
Michal Kazioraa5b4fb2014-07-23 12:20:33 +02006734 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Sara Sharon50ea05e2015-12-30 16:06:04 +02006735 struct ieee80211_sta *sta = params->sta;
6736 enum ieee80211_ampdu_mlme_action action = params->action;
6737 u16 tid = params->tid;
Michal Kazioraa5b4fb2014-07-23 12:20:33 +02006738
Michal Kazior7aa7a722014-08-25 12:09:38 +02006739 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 +02006740 arvif->vdev_id, sta->addr, tid, action);
6741
6742 switch (action) {
6743 case IEEE80211_AMPDU_RX_START:
6744 case IEEE80211_AMPDU_RX_STOP:
6745 /* HTT AddBa/DelBa events trigger mac80211 Rx BA session
6746 * creation/removal. Do we need to verify this?
6747 */
6748 return 0;
6749 case IEEE80211_AMPDU_TX_START:
6750 case IEEE80211_AMPDU_TX_STOP_CONT:
6751 case IEEE80211_AMPDU_TX_STOP_FLUSH:
6752 case IEEE80211_AMPDU_TX_STOP_FLUSH_CONT:
6753 case IEEE80211_AMPDU_TX_OPERATIONAL:
6754 /* Firmware offloads Tx aggregation entirely so deny mac80211
6755 * Tx aggregation requests.
6756 */
6757 return -EOPNOTSUPP;
6758 }
6759
6760 return -EINVAL;
6761}
6762
Michal Kazior500ff9f2015-03-31 10:26:21 +00006763static void
Michal Kaziord7bf4b42015-06-03 12:16:54 +02006764ath10k_mac_update_rx_channel(struct ath10k *ar,
6765 struct ieee80211_chanctx_conf *ctx,
6766 struct ieee80211_vif_chanctx_switch *vifs,
6767 int n_vifs)
Michal Kazior500ff9f2015-03-31 10:26:21 +00006768{
6769 struct cfg80211_chan_def *def = NULL;
6770
6771 /* Both locks are required because ar->rx_channel is modified. This
6772 * allows readers to hold either lock.
6773 */
6774 lockdep_assert_held(&ar->conf_mutex);
6775 lockdep_assert_held(&ar->data_lock);
6776
Michal Kaziord7bf4b42015-06-03 12:16:54 +02006777 WARN_ON(ctx && vifs);
6778 WARN_ON(vifs && n_vifs != 1);
6779
Michal Kazior500ff9f2015-03-31 10:26:21 +00006780 /* FIXME: Sort of an optimization and a workaround. Peers and vifs are
6781 * on a linked list now. Doing a lookup peer -> vif -> chanctx for each
6782 * ppdu on Rx may reduce performance on low-end systems. It should be
6783 * possible to make tables/hashmaps to speed the lookup up (be vary of
6784 * cpu data cache lines though regarding sizes) but to keep the initial
6785 * implementation simple and less intrusive fallback to the slow lookup
6786 * only for multi-channel cases. Single-channel cases will remain to
6787 * use the old channel derival and thus performance should not be
6788 * affected much.
6789 */
6790 rcu_read_lock();
Michal Kaziord7bf4b42015-06-03 12:16:54 +02006791 if (!ctx && ath10k_mac_num_chanctxs(ar) == 1) {
Michal Kazior500ff9f2015-03-31 10:26:21 +00006792 ieee80211_iter_chan_contexts_atomic(ar->hw,
Kalle Valo617b0f42015-10-05 17:56:35 +03006793 ath10k_mac_get_any_chandef_iter,
6794 &def);
Michal Kaziord7bf4b42015-06-03 12:16:54 +02006795
6796 if (vifs)
6797 def = &vifs[0].new_ctx->def;
6798
Michal Kazior500ff9f2015-03-31 10:26:21 +00006799 ar->rx_channel = def->chan;
Michal Kaziord7bf4b42015-06-03 12:16:54 +02006800 } else if (ctx && ath10k_mac_num_chanctxs(ar) == 0) {
6801 ar->rx_channel = ctx->def.chan;
Michal Kazior500ff9f2015-03-31 10:26:21 +00006802 } else {
6803 ar->rx_channel = NULL;
6804 }
6805 rcu_read_unlock();
6806}
6807
Michal Kazior7be6d1b2015-09-03 10:44:51 +02006808static void
6809ath10k_mac_update_vif_chan(struct ath10k *ar,
6810 struct ieee80211_vif_chanctx_switch *vifs,
6811 int n_vifs)
6812{
6813 struct ath10k_vif *arvif;
6814 int ret;
6815 int i;
6816
6817 lockdep_assert_held(&ar->conf_mutex);
6818
6819 /* First stop monitor interface. Some FW versions crash if there's a
6820 * lone monitor interface.
6821 */
6822 if (ar->monitor_started)
6823 ath10k_monitor_stop(ar);
6824
6825 for (i = 0; i < n_vifs; i++) {
6826 arvif = ath10k_vif_to_arvif(vifs[i].vif);
6827
6828 ath10k_dbg(ar, ATH10K_DBG_MAC,
6829 "mac chanctx switch vdev_id %i freq %hu->%hu width %d->%d\n",
6830 arvif->vdev_id,
6831 vifs[i].old_ctx->def.chan->center_freq,
6832 vifs[i].new_ctx->def.chan->center_freq,
6833 vifs[i].old_ctx->def.width,
6834 vifs[i].new_ctx->def.width);
6835
6836 if (WARN_ON(!arvif->is_started))
6837 continue;
6838
6839 if (WARN_ON(!arvif->is_up))
6840 continue;
6841
6842 ret = ath10k_wmi_vdev_down(ar, arvif->vdev_id);
6843 if (ret) {
6844 ath10k_warn(ar, "failed to down vdev %d: %d\n",
6845 arvif->vdev_id, ret);
6846 continue;
6847 }
6848 }
6849
6850 /* All relevant vdevs are downed and associated channel resources
6851 * should be available for the channel switch now.
6852 */
6853
6854 spin_lock_bh(&ar->data_lock);
6855 ath10k_mac_update_rx_channel(ar, NULL, vifs, n_vifs);
6856 spin_unlock_bh(&ar->data_lock);
6857
6858 for (i = 0; i < n_vifs; i++) {
6859 arvif = ath10k_vif_to_arvif(vifs[i].vif);
6860
6861 if (WARN_ON(!arvif->is_started))
6862 continue;
6863
6864 if (WARN_ON(!arvif->is_up))
6865 continue;
6866
6867 ret = ath10k_mac_setup_bcn_tmpl(arvif);
6868 if (ret)
6869 ath10k_warn(ar, "failed to update bcn tmpl during csa: %d\n",
6870 ret);
6871
6872 ret = ath10k_mac_setup_prb_tmpl(arvif);
6873 if (ret)
6874 ath10k_warn(ar, "failed to update prb tmpl during csa: %d\n",
6875 ret);
6876
6877 ret = ath10k_vdev_restart(arvif, &vifs[i].new_ctx->def);
6878 if (ret) {
6879 ath10k_warn(ar, "failed to restart vdev %d: %d\n",
6880 arvif->vdev_id, ret);
6881 continue;
6882 }
6883
6884 ret = ath10k_wmi_vdev_up(arvif->ar, arvif->vdev_id, arvif->aid,
6885 arvif->bssid);
6886 if (ret) {
6887 ath10k_warn(ar, "failed to bring vdev up %d: %d\n",
6888 arvif->vdev_id, ret);
6889 continue;
6890 }
6891 }
6892
6893 ath10k_monitor_recalc(ar);
6894}
6895
Michal Kazior500ff9f2015-03-31 10:26:21 +00006896static int
6897ath10k_mac_op_add_chanctx(struct ieee80211_hw *hw,
6898 struct ieee80211_chanctx_conf *ctx)
6899{
6900 struct ath10k *ar = hw->priv;
Michal Kazior500ff9f2015-03-31 10:26:21 +00006901
6902 ath10k_dbg(ar, ATH10K_DBG_MAC,
6903 "mac chanctx add freq %hu width %d ptr %p\n",
6904 ctx->def.chan->center_freq, ctx->def.width, ctx);
6905
6906 mutex_lock(&ar->conf_mutex);
6907
6908 spin_lock_bh(&ar->data_lock);
Michal Kaziord7bf4b42015-06-03 12:16:54 +02006909 ath10k_mac_update_rx_channel(ar, ctx, NULL, 0);
Michal Kazior500ff9f2015-03-31 10:26:21 +00006910 spin_unlock_bh(&ar->data_lock);
6911
6912 ath10k_recalc_radar_detection(ar);
6913 ath10k_monitor_recalc(ar);
6914
6915 mutex_unlock(&ar->conf_mutex);
6916
6917 return 0;
6918}
6919
6920static void
6921ath10k_mac_op_remove_chanctx(struct ieee80211_hw *hw,
6922 struct ieee80211_chanctx_conf *ctx)
6923{
6924 struct ath10k *ar = hw->priv;
6925
6926 ath10k_dbg(ar, ATH10K_DBG_MAC,
6927 "mac chanctx remove freq %hu width %d ptr %p\n",
6928 ctx->def.chan->center_freq, ctx->def.width, ctx);
6929
6930 mutex_lock(&ar->conf_mutex);
6931
6932 spin_lock_bh(&ar->data_lock);
Michal Kaziord7bf4b42015-06-03 12:16:54 +02006933 ath10k_mac_update_rx_channel(ar, NULL, NULL, 0);
Michal Kazior500ff9f2015-03-31 10:26:21 +00006934 spin_unlock_bh(&ar->data_lock);
6935
6936 ath10k_recalc_radar_detection(ar);
6937 ath10k_monitor_recalc(ar);
6938
6939 mutex_unlock(&ar->conf_mutex);
6940}
6941
Michal Kazior9713e3d2015-09-03 10:44:52 +02006942struct ath10k_mac_change_chanctx_arg {
6943 struct ieee80211_chanctx_conf *ctx;
6944 struct ieee80211_vif_chanctx_switch *vifs;
6945 int n_vifs;
6946 int next_vif;
6947};
6948
6949static void
6950ath10k_mac_change_chanctx_cnt_iter(void *data, u8 *mac,
6951 struct ieee80211_vif *vif)
6952{
6953 struct ath10k_mac_change_chanctx_arg *arg = data;
6954
6955 if (rcu_access_pointer(vif->chanctx_conf) != arg->ctx)
6956 return;
6957
6958 arg->n_vifs++;
6959}
6960
6961static void
6962ath10k_mac_change_chanctx_fill_iter(void *data, u8 *mac,
6963 struct ieee80211_vif *vif)
6964{
6965 struct ath10k_mac_change_chanctx_arg *arg = data;
6966 struct ieee80211_chanctx_conf *ctx;
6967
6968 ctx = rcu_access_pointer(vif->chanctx_conf);
6969 if (ctx != arg->ctx)
6970 return;
6971
6972 if (WARN_ON(arg->next_vif == arg->n_vifs))
6973 return;
6974
6975 arg->vifs[arg->next_vif].vif = vif;
6976 arg->vifs[arg->next_vif].old_ctx = ctx;
6977 arg->vifs[arg->next_vif].new_ctx = ctx;
6978 arg->next_vif++;
6979}
6980
Michal Kazior500ff9f2015-03-31 10:26:21 +00006981static void
6982ath10k_mac_op_change_chanctx(struct ieee80211_hw *hw,
6983 struct ieee80211_chanctx_conf *ctx,
6984 u32 changed)
6985{
6986 struct ath10k *ar = hw->priv;
Michal Kazior9713e3d2015-09-03 10:44:52 +02006987 struct ath10k_mac_change_chanctx_arg arg = { .ctx = ctx };
Michal Kazior500ff9f2015-03-31 10:26:21 +00006988
6989 mutex_lock(&ar->conf_mutex);
6990
6991 ath10k_dbg(ar, ATH10K_DBG_MAC,
Michal Kazior089ab7a2015-06-03 12:16:55 +02006992 "mac chanctx change freq %hu width %d ptr %p changed %x\n",
6993 ctx->def.chan->center_freq, ctx->def.width, ctx, changed);
Michal Kazior500ff9f2015-03-31 10:26:21 +00006994
6995 /* This shouldn't really happen because channel switching should use
6996 * switch_vif_chanctx().
6997 */
6998 if (WARN_ON(changed & IEEE80211_CHANCTX_CHANGE_CHANNEL))
6999 goto unlock;
7000
Michal Kazior9713e3d2015-09-03 10:44:52 +02007001 if (changed & IEEE80211_CHANCTX_CHANGE_WIDTH) {
7002 ieee80211_iterate_active_interfaces_atomic(
7003 hw,
7004 IEEE80211_IFACE_ITER_NORMAL,
7005 ath10k_mac_change_chanctx_cnt_iter,
7006 &arg);
7007 if (arg.n_vifs == 0)
7008 goto radar;
7009
7010 arg.vifs = kcalloc(arg.n_vifs, sizeof(arg.vifs[0]),
7011 GFP_KERNEL);
7012 if (!arg.vifs)
7013 goto radar;
7014
7015 ieee80211_iterate_active_interfaces_atomic(
7016 hw,
7017 IEEE80211_IFACE_ITER_NORMAL,
7018 ath10k_mac_change_chanctx_fill_iter,
7019 &arg);
7020 ath10k_mac_update_vif_chan(ar, arg.vifs, arg.n_vifs);
7021 kfree(arg.vifs);
7022 }
7023
7024radar:
Michal Kazior500ff9f2015-03-31 10:26:21 +00007025 ath10k_recalc_radar_detection(ar);
7026
7027 /* FIXME: How to configure Rx chains properly? */
7028
7029 /* No other actions are actually necessary. Firmware maintains channel
7030 * definitions per vdev internally and there's no host-side channel
7031 * context abstraction to configure, e.g. channel width.
7032 */
7033
7034unlock:
7035 mutex_unlock(&ar->conf_mutex);
7036}
7037
7038static int
7039ath10k_mac_op_assign_vif_chanctx(struct ieee80211_hw *hw,
7040 struct ieee80211_vif *vif,
7041 struct ieee80211_chanctx_conf *ctx)
7042{
7043 struct ath10k *ar = hw->priv;
Michal Kazior500ff9f2015-03-31 10:26:21 +00007044 struct ath10k_vif *arvif = (void *)vif->drv_priv;
7045 int ret;
7046
7047 mutex_lock(&ar->conf_mutex);
7048
7049 ath10k_dbg(ar, ATH10K_DBG_MAC,
7050 "mac chanctx assign ptr %p vdev_id %i\n",
7051 ctx, arvif->vdev_id);
7052
7053 if (WARN_ON(arvif->is_started)) {
7054 mutex_unlock(&ar->conf_mutex);
7055 return -EBUSY;
7056 }
7057
Michal Kazior089ab7a2015-06-03 12:16:55 +02007058 ret = ath10k_vdev_start(arvif, &ctx->def);
Michal Kazior500ff9f2015-03-31 10:26:21 +00007059 if (ret) {
7060 ath10k_warn(ar, "failed to start vdev %i addr %pM on freq %d: %d\n",
7061 arvif->vdev_id, vif->addr,
Michal Kazior089ab7a2015-06-03 12:16:55 +02007062 ctx->def.chan->center_freq, ret);
Michal Kazior500ff9f2015-03-31 10:26:21 +00007063 goto err;
7064 }
7065
7066 arvif->is_started = true;
7067
Michal Kaziorf23e587e2015-07-09 13:08:37 +02007068 ret = ath10k_mac_vif_setup_ps(arvif);
7069 if (ret) {
7070 ath10k_warn(ar, "failed to update vdev %i ps: %d\n",
7071 arvif->vdev_id, ret);
7072 goto err_stop;
7073 }
7074
Michal Kazior500ff9f2015-03-31 10:26:21 +00007075 if (vif->type == NL80211_IFTYPE_MONITOR) {
7076 ret = ath10k_wmi_vdev_up(ar, arvif->vdev_id, 0, vif->addr);
7077 if (ret) {
7078 ath10k_warn(ar, "failed to up monitor vdev %i: %d\n",
7079 arvif->vdev_id, ret);
7080 goto err_stop;
7081 }
7082
7083 arvif->is_up = true;
7084 }
7085
7086 mutex_unlock(&ar->conf_mutex);
7087 return 0;
7088
7089err_stop:
7090 ath10k_vdev_stop(arvif);
7091 arvif->is_started = false;
Michal Kaziorf23e587e2015-07-09 13:08:37 +02007092 ath10k_mac_vif_setup_ps(arvif);
Michal Kazior500ff9f2015-03-31 10:26:21 +00007093
7094err:
7095 mutex_unlock(&ar->conf_mutex);
7096 return ret;
7097}
7098
7099static void
7100ath10k_mac_op_unassign_vif_chanctx(struct ieee80211_hw *hw,
7101 struct ieee80211_vif *vif,
7102 struct ieee80211_chanctx_conf *ctx)
7103{
7104 struct ath10k *ar = hw->priv;
7105 struct ath10k_vif *arvif = (void *)vif->drv_priv;
7106 int ret;
7107
7108 mutex_lock(&ar->conf_mutex);
7109
7110 ath10k_dbg(ar, ATH10K_DBG_MAC,
7111 "mac chanctx unassign ptr %p vdev_id %i\n",
7112 ctx, arvif->vdev_id);
7113
7114 WARN_ON(!arvif->is_started);
7115
7116 if (vif->type == NL80211_IFTYPE_MONITOR) {
7117 WARN_ON(!arvif->is_up);
7118
7119 ret = ath10k_wmi_vdev_down(ar, arvif->vdev_id);
7120 if (ret)
7121 ath10k_warn(ar, "failed to down monitor vdev %i: %d\n",
7122 arvif->vdev_id, ret);
7123
7124 arvif->is_up = false;
7125 }
7126
7127 ret = ath10k_vdev_stop(arvif);
7128 if (ret)
7129 ath10k_warn(ar, "failed to stop vdev %i: %d\n",
7130 arvif->vdev_id, ret);
7131
7132 arvif->is_started = false;
7133
7134 mutex_unlock(&ar->conf_mutex);
7135}
7136
7137static int
7138ath10k_mac_op_switch_vif_chanctx(struct ieee80211_hw *hw,
7139 struct ieee80211_vif_chanctx_switch *vifs,
7140 int n_vifs,
7141 enum ieee80211_chanctx_switch_mode mode)
7142{
7143 struct ath10k *ar = hw->priv;
Michal Kazior500ff9f2015-03-31 10:26:21 +00007144
7145 mutex_lock(&ar->conf_mutex);
7146
7147 ath10k_dbg(ar, ATH10K_DBG_MAC,
7148 "mac chanctx switch n_vifs %d mode %d\n",
7149 n_vifs, mode);
Michal Kazior7be6d1b2015-09-03 10:44:51 +02007150 ath10k_mac_update_vif_chan(ar, vifs, n_vifs);
Michal Kazior500ff9f2015-03-31 10:26:21 +00007151
7152 mutex_unlock(&ar->conf_mutex);
7153 return 0;
7154}
7155
Kalle Valo5e3dd152013-06-12 20:52:10 +03007156static const struct ieee80211_ops ath10k_ops = {
Michal Kaziorf2f6eca2016-03-01 11:32:46 +01007157 .tx = ath10k_mac_op_tx,
Michal Kazior29946872016-03-06 16:14:34 +02007158 .wake_tx_queue = ath10k_mac_op_wake_tx_queue,
Kalle Valo5e3dd152013-06-12 20:52:10 +03007159 .start = ath10k_start,
7160 .stop = ath10k_stop,
7161 .config = ath10k_config,
7162 .add_interface = ath10k_add_interface,
7163 .remove_interface = ath10k_remove_interface,
7164 .configure_filter = ath10k_configure_filter,
7165 .bss_info_changed = ath10k_bss_info_changed,
7166 .hw_scan = ath10k_hw_scan,
7167 .cancel_hw_scan = ath10k_cancel_hw_scan,
7168 .set_key = ath10k_set_key,
SenthilKumar Jegadeesan627613f2015-01-29 13:50:38 +02007169 .set_default_unicast_key = ath10k_set_default_unicast_key,
Kalle Valo5e3dd152013-06-12 20:52:10 +03007170 .sta_state = ath10k_sta_state,
7171 .conf_tx = ath10k_conf_tx,
7172 .remain_on_channel = ath10k_remain_on_channel,
7173 .cancel_remain_on_channel = ath10k_cancel_remain_on_channel,
7174 .set_rts_threshold = ath10k_set_rts_threshold,
Michal Kazior92092fe2015-08-03 11:16:43 +02007175 .set_frag_threshold = ath10k_mac_op_set_frag_threshold,
Kalle Valo5e3dd152013-06-12 20:52:10 +03007176 .flush = ath10k_flush,
7177 .tx_last_beacon = ath10k_tx_last_beacon,
Ben Greear46acf7b2014-05-16 17:15:38 +03007178 .set_antenna = ath10k_set_antenna,
7179 .get_antenna = ath10k_get_antenna,
Eliad Pellercf2c92d2014-11-04 11:43:54 +02007180 .reconfig_complete = ath10k_reconfig_complete,
Michal Kazior2e1dea42013-07-31 10:32:40 +02007181 .get_survey = ath10k_get_survey,
Michal Kazior3ae54222015-03-31 10:49:20 +00007182 .set_bitrate_mask = ath10k_mac_op_set_bitrate_mask,
Michal Kazior9797feb2014-02-14 14:49:48 +01007183 .sta_rc_update = ath10k_sta_rc_update,
Chun-Yeow Yeoh26ebbcc2014-02-25 09:29:54 +02007184 .get_tsf = ath10k_get_tsf,
Michal Kazioraa5b4fb2014-07-23 12:20:33 +02007185 .ampdu_action = ath10k_ampdu_action,
Ben Greear6cddcc72014-09-29 14:41:46 +03007186 .get_et_sset_count = ath10k_debug_get_et_sset_count,
7187 .get_et_stats = ath10k_debug_get_et_stats,
7188 .get_et_strings = ath10k_debug_get_et_strings,
Michal Kazior500ff9f2015-03-31 10:26:21 +00007189 .add_chanctx = ath10k_mac_op_add_chanctx,
7190 .remove_chanctx = ath10k_mac_op_remove_chanctx,
7191 .change_chanctx = ath10k_mac_op_change_chanctx,
7192 .assign_vif_chanctx = ath10k_mac_op_assign_vif_chanctx,
7193 .unassign_vif_chanctx = ath10k_mac_op_unassign_vif_chanctx,
7194 .switch_vif_chanctx = ath10k_mac_op_switch_vif_chanctx,
Kalle Valo43d2a302014-09-10 18:23:30 +03007195
7196 CFG80211_TESTMODE_CMD(ath10k_tm_cmd)
7197
Michal Kazior8cd13ca2013-07-16 09:38:54 +02007198#ifdef CONFIG_PM
Janusz Dziedzic5fd3ac32015-03-23 17:32:53 +02007199 .suspend = ath10k_wow_op_suspend,
7200 .resume = ath10k_wow_op_resume,
Michal Kazior8cd13ca2013-07-16 09:38:54 +02007201#endif
Rajkumar Manoharanf5045982015-01-12 14:07:27 +02007202#ifdef CONFIG_MAC80211_DEBUGFS
7203 .sta_add_debugfs = ath10k_sta_add_debugfs,
7204#endif
Kalle Valo5e3dd152013-06-12 20:52:10 +03007205};
7206
Kalle Valo5e3dd152013-06-12 20:52:10 +03007207#define CHAN2G(_channel, _freq, _flags) { \
7208 .band = IEEE80211_BAND_2GHZ, \
7209 .hw_value = (_channel), \
7210 .center_freq = (_freq), \
7211 .flags = (_flags), \
7212 .max_antenna_gain = 0, \
7213 .max_power = 30, \
7214}
7215
7216#define CHAN5G(_channel, _freq, _flags) { \
7217 .band = IEEE80211_BAND_5GHZ, \
7218 .hw_value = (_channel), \
7219 .center_freq = (_freq), \
7220 .flags = (_flags), \
7221 .max_antenna_gain = 0, \
7222 .max_power = 30, \
7223}
7224
7225static const struct ieee80211_channel ath10k_2ghz_channels[] = {
7226 CHAN2G(1, 2412, 0),
7227 CHAN2G(2, 2417, 0),
7228 CHAN2G(3, 2422, 0),
7229 CHAN2G(4, 2427, 0),
7230 CHAN2G(5, 2432, 0),
7231 CHAN2G(6, 2437, 0),
7232 CHAN2G(7, 2442, 0),
7233 CHAN2G(8, 2447, 0),
7234 CHAN2G(9, 2452, 0),
7235 CHAN2G(10, 2457, 0),
7236 CHAN2G(11, 2462, 0),
7237 CHAN2G(12, 2467, 0),
7238 CHAN2G(13, 2472, 0),
7239 CHAN2G(14, 2484, 0),
7240};
7241
7242static const struct ieee80211_channel ath10k_5ghz_channels[] = {
Michal Kazior429ff562013-06-26 08:54:54 +02007243 CHAN5G(36, 5180, 0),
7244 CHAN5G(40, 5200, 0),
7245 CHAN5G(44, 5220, 0),
7246 CHAN5G(48, 5240, 0),
7247 CHAN5G(52, 5260, 0),
7248 CHAN5G(56, 5280, 0),
7249 CHAN5G(60, 5300, 0),
7250 CHAN5G(64, 5320, 0),
7251 CHAN5G(100, 5500, 0),
7252 CHAN5G(104, 5520, 0),
7253 CHAN5G(108, 5540, 0),
7254 CHAN5G(112, 5560, 0),
7255 CHAN5G(116, 5580, 0),
7256 CHAN5G(120, 5600, 0),
7257 CHAN5G(124, 5620, 0),
7258 CHAN5G(128, 5640, 0),
7259 CHAN5G(132, 5660, 0),
7260 CHAN5G(136, 5680, 0),
7261 CHAN5G(140, 5700, 0),
Peter Oh4a7898f2015-03-18 11:39:18 -07007262 CHAN5G(144, 5720, 0),
Michal Kazior429ff562013-06-26 08:54:54 +02007263 CHAN5G(149, 5745, 0),
7264 CHAN5G(153, 5765, 0),
7265 CHAN5G(157, 5785, 0),
7266 CHAN5G(161, 5805, 0),
7267 CHAN5G(165, 5825, 0),
Kalle Valo5e3dd152013-06-12 20:52:10 +03007268};
7269
Michal Kaziore7b54192014-08-07 11:03:27 +02007270struct ath10k *ath10k_mac_create(size_t priv_size)
Kalle Valo5e3dd152013-06-12 20:52:10 +03007271{
7272 struct ieee80211_hw *hw;
7273 struct ath10k *ar;
7274
Michal Kaziore7b54192014-08-07 11:03:27 +02007275 hw = ieee80211_alloc_hw(sizeof(struct ath10k) + priv_size, &ath10k_ops);
Kalle Valo5e3dd152013-06-12 20:52:10 +03007276 if (!hw)
7277 return NULL;
7278
7279 ar = hw->priv;
7280 ar->hw = hw;
7281
7282 return ar;
7283}
7284
7285void ath10k_mac_destroy(struct ath10k *ar)
7286{
7287 ieee80211_free_hw(ar->hw);
7288}
7289
7290static const struct ieee80211_iface_limit ath10k_if_limits[] = {
7291 {
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05307292 .max = 8,
7293 .types = BIT(NL80211_IFTYPE_STATION)
7294 | BIT(NL80211_IFTYPE_P2P_CLIENT)
Michal Kaziord531cb82013-07-31 10:55:13 +02007295 },
7296 {
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05307297 .max = 3,
7298 .types = BIT(NL80211_IFTYPE_P2P_GO)
Michal Kaziord531cb82013-07-31 10:55:13 +02007299 },
7300 {
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05307301 .max = 1,
7302 .types = BIT(NL80211_IFTYPE_P2P_DEVICE)
Michal Kazior75d2bd42014-12-12 12:41:39 +01007303 },
7304 {
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05307305 .max = 7,
7306 .types = BIT(NL80211_IFTYPE_AP)
Bob Copelandb6c7baf2015-09-09 12:47:36 -04007307#ifdef CONFIG_MAC80211_MESH
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05307308 | BIT(NL80211_IFTYPE_MESH_POINT)
Bob Copelandb6c7baf2015-09-09 12:47:36 -04007309#endif
Michal Kaziord531cb82013-07-31 10:55:13 +02007310 },
Kalle Valo5e3dd152013-06-12 20:52:10 +03007311};
7312
Bartosz Markowskif2595092013-12-10 16:20:39 +01007313static const struct ieee80211_iface_limit ath10k_10x_if_limits[] = {
Marek Puzyniake8a50f82013-11-20 09:59:47 +02007314 {
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05307315 .max = 8,
7316 .types = BIT(NL80211_IFTYPE_AP)
Bob Copelandb6c7baf2015-09-09 12:47:36 -04007317#ifdef CONFIG_MAC80211_MESH
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05307318 | BIT(NL80211_IFTYPE_MESH_POINT)
Bob Copelandb6c7baf2015-09-09 12:47:36 -04007319#endif
Marek Puzyniake8a50f82013-11-20 09:59:47 +02007320 },
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05307321 {
7322 .max = 1,
7323 .types = BIT(NL80211_IFTYPE_STATION)
7324 },
Marek Puzyniake8a50f82013-11-20 09:59:47 +02007325};
Marek Puzyniake8a50f82013-11-20 09:59:47 +02007326
7327static const struct ieee80211_iface_combination ath10k_if_comb[] = {
7328 {
7329 .limits = ath10k_if_limits,
7330 .n_limits = ARRAY_SIZE(ath10k_if_limits),
7331 .max_interfaces = 8,
7332 .num_different_channels = 1,
7333 .beacon_int_infra_match = true,
7334 },
Bartosz Markowskif2595092013-12-10 16:20:39 +01007335};
7336
7337static const struct ieee80211_iface_combination ath10k_10x_if_comb[] = {
Marek Puzyniake8a50f82013-11-20 09:59:47 +02007338 {
Bartosz Markowskif2595092013-12-10 16:20:39 +01007339 .limits = ath10k_10x_if_limits,
7340 .n_limits = ARRAY_SIZE(ath10k_10x_if_limits),
Marek Puzyniake8a50f82013-11-20 09:59:47 +02007341 .max_interfaces = 8,
7342 .num_different_channels = 1,
7343 .beacon_int_infra_match = true,
Bartosz Markowskif2595092013-12-10 16:20:39 +01007344#ifdef CONFIG_ATH10K_DFS_CERTIFIED
Marek Puzyniake8a50f82013-11-20 09:59:47 +02007345 .radar_detect_widths = BIT(NL80211_CHAN_WIDTH_20_NOHT) |
7346 BIT(NL80211_CHAN_WIDTH_20) |
7347 BIT(NL80211_CHAN_WIDTH_40) |
7348 BIT(NL80211_CHAN_WIDTH_80),
Marek Puzyniake8a50f82013-11-20 09:59:47 +02007349#endif
Bartosz Markowskif2595092013-12-10 16:20:39 +01007350 },
Kalle Valo5e3dd152013-06-12 20:52:10 +03007351};
7352
Michal Kaziorcf327842015-03-31 10:26:25 +00007353static const struct ieee80211_iface_limit ath10k_tlv_if_limit[] = {
7354 {
7355 .max = 2,
Michal Kaziored25b112015-07-09 13:08:39 +02007356 .types = BIT(NL80211_IFTYPE_STATION),
7357 },
7358 {
7359 .max = 2,
7360 .types = BIT(NL80211_IFTYPE_AP) |
Bob Copelandb6c7baf2015-09-09 12:47:36 -04007361#ifdef CONFIG_MAC80211_MESH
7362 BIT(NL80211_IFTYPE_MESH_POINT) |
7363#endif
Michal Kaziorcf327842015-03-31 10:26:25 +00007364 BIT(NL80211_IFTYPE_P2P_CLIENT) |
7365 BIT(NL80211_IFTYPE_P2P_GO),
7366 },
7367 {
7368 .max = 1,
7369 .types = BIT(NL80211_IFTYPE_P2P_DEVICE),
7370 },
7371};
7372
Michal Kaziored25b112015-07-09 13:08:39 +02007373static const struct ieee80211_iface_limit ath10k_tlv_qcs_if_limit[] = {
7374 {
7375 .max = 2,
7376 .types = BIT(NL80211_IFTYPE_STATION),
7377 },
7378 {
7379 .max = 2,
7380 .types = BIT(NL80211_IFTYPE_P2P_CLIENT),
7381 },
7382 {
7383 .max = 1,
7384 .types = BIT(NL80211_IFTYPE_AP) |
Bob Copelandb6c7baf2015-09-09 12:47:36 -04007385#ifdef CONFIG_MAC80211_MESH
7386 BIT(NL80211_IFTYPE_MESH_POINT) |
7387#endif
Michal Kaziored25b112015-07-09 13:08:39 +02007388 BIT(NL80211_IFTYPE_P2P_GO),
7389 },
7390 {
7391 .max = 1,
7392 .types = BIT(NL80211_IFTYPE_P2P_DEVICE),
7393 },
7394};
7395
Michal Kaziorcf327842015-03-31 10:26:25 +00007396static const struct ieee80211_iface_limit ath10k_tlv_if_limit_ibss[] = {
7397 {
7398 .max = 1,
7399 .types = BIT(NL80211_IFTYPE_STATION),
7400 },
7401 {
7402 .max = 1,
7403 .types = BIT(NL80211_IFTYPE_ADHOC),
7404 },
7405};
7406
7407/* FIXME: This is not thouroughly tested. These combinations may over- or
7408 * underestimate hw/fw capabilities.
7409 */
7410static struct ieee80211_iface_combination ath10k_tlv_if_comb[] = {
7411 {
7412 .limits = ath10k_tlv_if_limit,
7413 .num_different_channels = 1,
Michal Kaziored25b112015-07-09 13:08:39 +02007414 .max_interfaces = 4,
Michal Kaziorcf327842015-03-31 10:26:25 +00007415 .n_limits = ARRAY_SIZE(ath10k_tlv_if_limit),
7416 },
7417 {
7418 .limits = ath10k_tlv_if_limit_ibss,
7419 .num_different_channels = 1,
7420 .max_interfaces = 2,
7421 .n_limits = ARRAY_SIZE(ath10k_tlv_if_limit_ibss),
7422 },
7423};
7424
7425static struct ieee80211_iface_combination ath10k_tlv_qcs_if_comb[] = {
7426 {
7427 .limits = ath10k_tlv_if_limit,
Michal Kaziored25b112015-07-09 13:08:39 +02007428 .num_different_channels = 1,
7429 .max_interfaces = 4,
Michal Kaziorcf327842015-03-31 10:26:25 +00007430 .n_limits = ARRAY_SIZE(ath10k_tlv_if_limit),
7431 },
7432 {
Michal Kaziored25b112015-07-09 13:08:39 +02007433 .limits = ath10k_tlv_qcs_if_limit,
7434 .num_different_channels = 2,
7435 .max_interfaces = 4,
7436 .n_limits = ARRAY_SIZE(ath10k_tlv_qcs_if_limit),
7437 },
7438 {
Michal Kaziorcf327842015-03-31 10:26:25 +00007439 .limits = ath10k_tlv_if_limit_ibss,
7440 .num_different_channels = 1,
7441 .max_interfaces = 2,
7442 .n_limits = ARRAY_SIZE(ath10k_tlv_if_limit_ibss),
7443 },
7444};
7445
Raja Manicf36fef2015-06-22 20:22:25 +05307446static const struct ieee80211_iface_limit ath10k_10_4_if_limits[] = {
7447 {
7448 .max = 1,
7449 .types = BIT(NL80211_IFTYPE_STATION),
7450 },
7451 {
7452 .max = 16,
7453 .types = BIT(NL80211_IFTYPE_AP)
Bob Copelandb6c7baf2015-09-09 12:47:36 -04007454#ifdef CONFIG_MAC80211_MESH
7455 | BIT(NL80211_IFTYPE_MESH_POINT)
7456#endif
Raja Manicf36fef2015-06-22 20:22:25 +05307457 },
7458};
7459
7460static const struct ieee80211_iface_combination ath10k_10_4_if_comb[] = {
7461 {
7462 .limits = ath10k_10_4_if_limits,
7463 .n_limits = ARRAY_SIZE(ath10k_10_4_if_limits),
7464 .max_interfaces = 16,
7465 .num_different_channels = 1,
7466 .beacon_int_infra_match = true,
7467#ifdef CONFIG_ATH10K_DFS_CERTIFIED
7468 .radar_detect_widths = BIT(NL80211_CHAN_WIDTH_20_NOHT) |
7469 BIT(NL80211_CHAN_WIDTH_20) |
7470 BIT(NL80211_CHAN_WIDTH_40) |
7471 BIT(NL80211_CHAN_WIDTH_80),
7472#endif
7473 },
7474};
7475
Kalle Valo5e3dd152013-06-12 20:52:10 +03007476static void ath10k_get_arvif_iter(void *data, u8 *mac,
7477 struct ieee80211_vif *vif)
7478{
7479 struct ath10k_vif_iter *arvif_iter = data;
7480 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
7481
7482 if (arvif->vdev_id == arvif_iter->vdev_id)
7483 arvif_iter->arvif = arvif;
7484}
7485
7486struct ath10k_vif *ath10k_get_arvif(struct ath10k *ar, u32 vdev_id)
7487{
7488 struct ath10k_vif_iter arvif_iter;
7489 u32 flags;
7490
7491 memset(&arvif_iter, 0, sizeof(struct ath10k_vif_iter));
7492 arvif_iter.vdev_id = vdev_id;
7493
7494 flags = IEEE80211_IFACE_ITER_RESUME_ALL;
7495 ieee80211_iterate_active_interfaces_atomic(ar->hw,
7496 flags,
7497 ath10k_get_arvif_iter,
7498 &arvif_iter);
7499 if (!arvif_iter.arvif) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02007500 ath10k_warn(ar, "No VIF found for vdev %d\n", vdev_id);
Kalle Valo5e3dd152013-06-12 20:52:10 +03007501 return NULL;
7502 }
7503
7504 return arvif_iter.arvif;
7505}
7506
7507int ath10k_mac_register(struct ath10k *ar)
7508{
Johannes Berg3cb10942015-01-22 21:38:45 +01007509 static const u32 cipher_suites[] = {
7510 WLAN_CIPHER_SUITE_WEP40,
7511 WLAN_CIPHER_SUITE_WEP104,
7512 WLAN_CIPHER_SUITE_TKIP,
7513 WLAN_CIPHER_SUITE_CCMP,
7514 WLAN_CIPHER_SUITE_AES_CMAC,
7515 };
Kalle Valo5e3dd152013-06-12 20:52:10 +03007516 struct ieee80211_supported_band *band;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007517 void *channels;
7518 int ret;
7519
7520 SET_IEEE80211_PERM_ADDR(ar->hw, ar->mac_addr);
7521
7522 SET_IEEE80211_DEV(ar->hw, ar->dev);
7523
Michal Kaziorc94aa7e2015-03-24 12:38:11 +00007524 BUILD_BUG_ON((ARRAY_SIZE(ath10k_2ghz_channels) +
7525 ARRAY_SIZE(ath10k_5ghz_channels)) !=
7526 ATH10K_NUM_CHANS);
7527
Kalle Valo5e3dd152013-06-12 20:52:10 +03007528 if (ar->phy_capability & WHAL_WLAN_11G_CAPABILITY) {
7529 channels = kmemdup(ath10k_2ghz_channels,
7530 sizeof(ath10k_2ghz_channels),
7531 GFP_KERNEL);
Michal Kaziord6015b22013-07-22 14:13:30 +02007532 if (!channels) {
7533 ret = -ENOMEM;
7534 goto err_free;
7535 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03007536
7537 band = &ar->mac.sbands[IEEE80211_BAND_2GHZ];
7538 band->n_channels = ARRAY_SIZE(ath10k_2ghz_channels);
7539 band->channels = channels;
7540 band->n_bitrates = ath10k_g_rates_size;
7541 band->bitrates = ath10k_g_rates;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007542
7543 ar->hw->wiphy->bands[IEEE80211_BAND_2GHZ] = band;
7544 }
7545
7546 if (ar->phy_capability & WHAL_WLAN_11A_CAPABILITY) {
7547 channels = kmemdup(ath10k_5ghz_channels,
7548 sizeof(ath10k_5ghz_channels),
7549 GFP_KERNEL);
7550 if (!channels) {
Michal Kaziord6015b22013-07-22 14:13:30 +02007551 ret = -ENOMEM;
7552 goto err_free;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007553 }
7554
7555 band = &ar->mac.sbands[IEEE80211_BAND_5GHZ];
7556 band->n_channels = ARRAY_SIZE(ath10k_5ghz_channels);
7557 band->channels = channels;
7558 band->n_bitrates = ath10k_a_rates_size;
7559 band->bitrates = ath10k_a_rates;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007560 ar->hw->wiphy->bands[IEEE80211_BAND_5GHZ] = band;
7561 }
7562
Rajkumar Manoharan5036fe02015-10-27 17:51:14 +05307563 ath10k_mac_setup_ht_vht_cap(ar);
7564
Kalle Valo5e3dd152013-06-12 20:52:10 +03007565 ar->hw->wiphy->interface_modes =
7566 BIT(NL80211_IFTYPE_STATION) |
Bob Copelandb6c7baf2015-09-09 12:47:36 -04007567 BIT(NL80211_IFTYPE_AP) |
7568 BIT(NL80211_IFTYPE_MESH_POINT);
Bartosz Markowskid3541812013-12-10 16:20:40 +01007569
Rajkumar Manoharan166de3f2015-10-27 17:51:11 +05307570 ar->hw->wiphy->available_antennas_rx = ar->cfg_rx_chainmask;
7571 ar->hw->wiphy->available_antennas_tx = ar->cfg_tx_chainmask;
Ben Greear46acf7b2014-05-16 17:15:38 +03007572
Bartosz Markowskid3541812013-12-10 16:20:40 +01007573 if (!test_bit(ATH10K_FW_FEATURE_NO_P2P, ar->fw_features))
7574 ar->hw->wiphy->interface_modes |=
Michal Kazior75d2bd42014-12-12 12:41:39 +01007575 BIT(NL80211_IFTYPE_P2P_DEVICE) |
Bartosz Markowskid3541812013-12-10 16:20:40 +01007576 BIT(NL80211_IFTYPE_P2P_CLIENT) |
7577 BIT(NL80211_IFTYPE_P2P_GO);
Kalle Valo5e3dd152013-06-12 20:52:10 +03007578
Johannes Berg30686bf2015-06-02 21:39:54 +02007579 ieee80211_hw_set(ar->hw, SIGNAL_DBM);
7580 ieee80211_hw_set(ar->hw, SUPPORTS_PS);
7581 ieee80211_hw_set(ar->hw, SUPPORTS_DYNAMIC_PS);
7582 ieee80211_hw_set(ar->hw, MFP_CAPABLE);
7583 ieee80211_hw_set(ar->hw, REPORTS_TX_ACK_STATUS);
7584 ieee80211_hw_set(ar->hw, HAS_RATE_CONTROL);
7585 ieee80211_hw_set(ar->hw, AP_LINK_PS);
7586 ieee80211_hw_set(ar->hw, SPECTRUM_MGMT);
Johannes Berg30686bf2015-06-02 21:39:54 +02007587 ieee80211_hw_set(ar->hw, SUPPORT_FAST_XMIT);
7588 ieee80211_hw_set(ar->hw, CONNECTION_MONITOR);
7589 ieee80211_hw_set(ar->hw, SUPPORTS_PER_STA_GTK);
7590 ieee80211_hw_set(ar->hw, WANT_MONITOR_VIF);
7591 ieee80211_hw_set(ar->hw, CHANCTX_STA_CSA);
7592 ieee80211_hw_set(ar->hw, QUEUE_CONTROL);
Kalle Valo5e3dd152013-06-12 20:52:10 +03007593
David Liuccec9032015-07-24 20:25:32 +03007594 if (!test_bit(ATH10K_FLAG_RAW_MODE, &ar->dev_flags))
7595 ieee80211_hw_set(ar->hw, SW_CRYPTO_CONTROL);
7596
Eliad Peller0d8614b2014-09-10 14:07:36 +03007597 ar->hw->wiphy->features |= NL80211_FEATURE_STATIC_SMPS;
Janusz Dziedzic0cd9bc12015-04-10 13:23:23 +00007598 ar->hw->wiphy->flags |= WIPHY_FLAG_IBSS_RSN;
Eliad Peller0d8614b2014-09-10 14:07:36 +03007599
Kalle Valo5e3dd152013-06-12 20:52:10 +03007600 if (ar->ht_cap_info & WMI_HT_CAP_DYNAMIC_SMPS)
Eliad Peller0d8614b2014-09-10 14:07:36 +03007601 ar->hw->wiphy->features |= NL80211_FEATURE_DYNAMIC_SMPS;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007602
7603 if (ar->ht_cap_info & WMI_HT_CAP_ENABLED) {
Johannes Berg30686bf2015-06-02 21:39:54 +02007604 ieee80211_hw_set(ar->hw, AMPDU_AGGREGATION);
7605 ieee80211_hw_set(ar->hw, TX_AMPDU_SETUP_IN_HW);
Kalle Valo5e3dd152013-06-12 20:52:10 +03007606 }
7607
7608 ar->hw->wiphy->max_scan_ssids = WLAN_SCAN_PARAMS_MAX_SSID;
7609 ar->hw->wiphy->max_scan_ie_len = WLAN_SCAN_PARAMS_MAX_IE_LEN;
7610
7611 ar->hw->vif_data_size = sizeof(struct ath10k_vif);
Michal Kazior9797feb2014-02-14 14:49:48 +01007612 ar->hw->sta_data_size = sizeof(struct ath10k_sta);
Michal Kazior29946872016-03-06 16:14:34 +02007613 ar->hw->txq_data_size = sizeof(struct ath10k_txq);
Kalle Valo5e3dd152013-06-12 20:52:10 +03007614
Kalle Valo5e3dd152013-06-12 20:52:10 +03007615 ar->hw->max_listen_interval = ATH10K_MAX_HW_LISTEN_INTERVAL;
7616
Michal Kaziorfbb8f1b2015-01-13 16:30:12 +02007617 if (test_bit(WMI_SERVICE_BEACON_OFFLOAD, ar->wmi.svc_map)) {
7618 ar->hw->wiphy->flags |= WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD;
7619
7620 /* Firmware delivers WPS/P2P Probe Requests frames to driver so
7621 * that userspace (e.g. wpa_supplicant/hostapd) can generate
7622 * correct Probe Responses. This is more of a hack advert..
7623 */
7624 ar->hw->wiphy->probe_resp_offload |=
7625 NL80211_PROBE_RESP_OFFLOAD_SUPPORT_WPS |
7626 NL80211_PROBE_RESP_OFFLOAD_SUPPORT_WPS2 |
7627 NL80211_PROBE_RESP_OFFLOAD_SUPPORT_P2P;
7628 }
7629
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03007630 if (test_bit(WMI_SERVICE_TDLS, ar->wmi.svc_map))
7631 ar->hw->wiphy->flags |= WIPHY_FLAG_SUPPORTS_TDLS;
7632
Kalle Valo5e3dd152013-06-12 20:52:10 +03007633 ar->hw->wiphy->flags |= WIPHY_FLAG_HAS_REMAIN_ON_CHANNEL;
Michal Kaziorc2df44b2014-01-23 11:38:26 +01007634 ar->hw->wiphy->flags |= WIPHY_FLAG_HAS_CHANNEL_SWITCH;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007635 ar->hw->wiphy->max_remain_on_channel_duration = 5000;
7636
7637 ar->hw->wiphy->flags |= WIPHY_FLAG_AP_UAPSD;
Rajkumar Manoharan78157a12014-11-17 16:44:15 +02007638 ar->hw->wiphy->features |= NL80211_FEATURE_AP_MODE_CHAN_WIDTH_CHANGE;
7639
Janusz.Dziedzic@tieto.com37a0b392015-03-12 13:11:41 +01007640 ar->hw->wiphy->max_ap_assoc_sta = ar->max_num_stations;
7641
Janusz Dziedzic5fd3ac32015-03-23 17:32:53 +02007642 ret = ath10k_wow_init(ar);
7643 if (ret) {
7644 ath10k_warn(ar, "failed to init wow: %d\n", ret);
7645 goto err_free;
7646 }
7647
Janusz Dziedzicc7025342015-06-15 14:46:41 +03007648 wiphy_ext_feature_set(ar->hw->wiphy, NL80211_EXT_FEATURE_VHT_IBSS);
7649
Kalle Valo5e3dd152013-06-12 20:52:10 +03007650 /*
7651 * on LL hardware queues are managed entirely by the FW
7652 * so we only advertise to mac we can do the queues thing
7653 */
Michal Kazior96d828d2015-03-31 10:26:23 +00007654 ar->hw->queues = IEEE80211_MAX_QUEUES;
7655
7656 /* vdev_ids are used as hw queue numbers. Make sure offchan tx queue is
7657 * something that vdev_ids can't reach so that we don't stop the queue
7658 * accidentally.
7659 */
7660 ar->hw->offchannel_tx_hw_queue = IEEE80211_MAX_QUEUES - 1;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007661
Kalle Valo5cc7caf2014-12-17 12:20:54 +02007662 switch (ar->wmi.op_version) {
7663 case ATH10K_FW_WMI_OP_VERSION_MAIN:
Bartosz Markowskif2595092013-12-10 16:20:39 +01007664 ar->hw->wiphy->iface_combinations = ath10k_if_comb;
7665 ar->hw->wiphy->n_iface_combinations =
7666 ARRAY_SIZE(ath10k_if_comb);
Michal Kaziorcf850d12014-07-24 20:07:00 +03007667 ar->hw->wiphy->interface_modes |= BIT(NL80211_IFTYPE_ADHOC);
Kalle Valo5cc7caf2014-12-17 12:20:54 +02007668 break;
Michal Kaziorcf327842015-03-31 10:26:25 +00007669 case ATH10K_FW_WMI_OP_VERSION_TLV:
7670 if (test_bit(WMI_SERVICE_ADAPTIVE_OCS, ar->wmi.svc_map)) {
7671 ar->hw->wiphy->iface_combinations =
7672 ath10k_tlv_qcs_if_comb;
7673 ar->hw->wiphy->n_iface_combinations =
7674 ARRAY_SIZE(ath10k_tlv_qcs_if_comb);
7675 } else {
7676 ar->hw->wiphy->iface_combinations = ath10k_tlv_if_comb;
7677 ar->hw->wiphy->n_iface_combinations =
7678 ARRAY_SIZE(ath10k_tlv_if_comb);
7679 }
7680 ar->hw->wiphy->interface_modes |= BIT(NL80211_IFTYPE_ADHOC);
7681 break;
Kalle Valo5cc7caf2014-12-17 12:20:54 +02007682 case ATH10K_FW_WMI_OP_VERSION_10_1:
7683 case ATH10K_FW_WMI_OP_VERSION_10_2:
Rajkumar Manoharan4a16fbe2014-12-17 12:21:12 +02007684 case ATH10K_FW_WMI_OP_VERSION_10_2_4:
Kalle Valo5cc7caf2014-12-17 12:20:54 +02007685 ar->hw->wiphy->iface_combinations = ath10k_10x_if_comb;
7686 ar->hw->wiphy->n_iface_combinations =
7687 ARRAY_SIZE(ath10k_10x_if_comb);
7688 break;
Raja Mani9bd21322015-06-22 20:10:09 +05307689 case ATH10K_FW_WMI_OP_VERSION_10_4:
Raja Manicf36fef2015-06-22 20:22:25 +05307690 ar->hw->wiphy->iface_combinations = ath10k_10_4_if_comb;
7691 ar->hw->wiphy->n_iface_combinations =
7692 ARRAY_SIZE(ath10k_10_4_if_comb);
Raja Mani9bd21322015-06-22 20:10:09 +05307693 break;
Kalle Valo5cc7caf2014-12-17 12:20:54 +02007694 case ATH10K_FW_WMI_OP_VERSION_UNSET:
7695 case ATH10K_FW_WMI_OP_VERSION_MAX:
7696 WARN_ON(1);
7697 ret = -EINVAL;
7698 goto err_free;
Bartosz Markowskif2595092013-12-10 16:20:39 +01007699 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03007700
David Liuccec9032015-07-24 20:25:32 +03007701 if (!test_bit(ATH10K_FLAG_RAW_MODE, &ar->dev_flags))
7702 ar->hw->netdev_features = NETIF_F_HW_CSUM;
Michal Kazior7c199992013-07-31 10:47:57 +02007703
Janusz Dziedzic9702c682013-11-20 09:59:41 +02007704 if (config_enabled(CONFIG_ATH10K_DFS_CERTIFIED)) {
7705 /* Init ath dfs pattern detector */
7706 ar->ath_common.debug_mask = ATH_DBG_DFS;
7707 ar->dfs_detector = dfs_pattern_detector_init(&ar->ath_common,
7708 NL80211_DFS_UNSET);
7709
7710 if (!ar->dfs_detector)
Michal Kazior7aa7a722014-08-25 12:09:38 +02007711 ath10k_warn(ar, "failed to initialise DFS pattern detector\n");
Janusz Dziedzic9702c682013-11-20 09:59:41 +02007712 }
7713
Kalle Valo5e3dd152013-06-12 20:52:10 +03007714 ret = ath_regd_init(&ar->ath_common.regulatory, ar->hw->wiphy,
7715 ath10k_reg_notifier);
7716 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02007717 ath10k_err(ar, "failed to initialise regulatory: %i\n", ret);
Jeff Johnson0e339442015-10-08 09:15:53 -07007718 goto err_dfs_detector_exit;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007719 }
7720
Johannes Berg3cb10942015-01-22 21:38:45 +01007721 ar->hw->wiphy->cipher_suites = cipher_suites;
7722 ar->hw->wiphy->n_cipher_suites = ARRAY_SIZE(cipher_suites);
7723
Kalle Valo5e3dd152013-06-12 20:52:10 +03007724 ret = ieee80211_register_hw(ar->hw);
7725 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02007726 ath10k_err(ar, "failed to register ieee80211: %d\n", ret);
Jeff Johnson0e339442015-10-08 09:15:53 -07007727 goto err_dfs_detector_exit;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007728 }
7729
7730 if (!ath_is_world_regd(&ar->ath_common.regulatory)) {
7731 ret = regulatory_hint(ar->hw->wiphy,
7732 ar->ath_common.regulatory.alpha2);
7733 if (ret)
Michal Kaziord6015b22013-07-22 14:13:30 +02007734 goto err_unregister;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007735 }
7736
7737 return 0;
Michal Kaziord6015b22013-07-22 14:13:30 +02007738
7739err_unregister:
Kalle Valo5e3dd152013-06-12 20:52:10 +03007740 ieee80211_unregister_hw(ar->hw);
Jeff Johnson0e339442015-10-08 09:15:53 -07007741
7742err_dfs_detector_exit:
7743 if (config_enabled(CONFIG_ATH10K_DFS_CERTIFIED) && ar->dfs_detector)
7744 ar->dfs_detector->exit(ar->dfs_detector);
7745
Michal Kaziord6015b22013-07-22 14:13:30 +02007746err_free:
7747 kfree(ar->mac.sbands[IEEE80211_BAND_2GHZ].channels);
7748 kfree(ar->mac.sbands[IEEE80211_BAND_5GHZ].channels);
7749
Jeff Johnson0e339442015-10-08 09:15:53 -07007750 SET_IEEE80211_DEV(ar->hw, NULL);
Kalle Valo5e3dd152013-06-12 20:52:10 +03007751 return ret;
7752}
7753
7754void ath10k_mac_unregister(struct ath10k *ar)
7755{
7756 ieee80211_unregister_hw(ar->hw);
7757
Janusz Dziedzic9702c682013-11-20 09:59:41 +02007758 if (config_enabled(CONFIG_ATH10K_DFS_CERTIFIED) && ar->dfs_detector)
7759 ar->dfs_detector->exit(ar->dfs_detector);
7760
Kalle Valo5e3dd152013-06-12 20:52:10 +03007761 kfree(ar->mac.sbands[IEEE80211_BAND_2GHZ].channels);
7762 kfree(ar->mac.sbands[IEEE80211_BAND_5GHZ].channels);
7763
7764 SET_IEEE80211_DEV(ar->hw, NULL);
7765}