blob: 6146a293601a7fea098a353aeb11fc803f5523a4 [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
Marek Puzyniak7390ed32015-03-30 09:51:52 +0300621static int ath10k_peer_create(struct ath10k *ar, u32 vdev_id, const u8 *addr,
622 enum wmi_peer_type peer_type)
Kalle Valo5e3dd152013-06-12 20:52:10 +0300623{
Michal Kaziore04cafb2015-08-05 12:15:24 +0200624 struct ath10k_vif *arvif;
625 int num_peers = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300626 int ret;
627
628 lockdep_assert_held(&ar->conf_mutex);
629
Michal Kaziore04cafb2015-08-05 12:15:24 +0200630 num_peers = ar->num_peers;
631
632 /* Each vdev consumes a peer entry as well */
633 list_for_each_entry(arvif, &ar->arvifs, list)
634 num_peers++;
635
636 if (num_peers >= ar->max_num_peers)
Michal Kaziorcfd10612014-11-25 15:16:05 +0100637 return -ENOBUFS;
638
Marek Puzyniak7390ed32015-03-30 09:51:52 +0300639 ret = ath10k_wmi_peer_create(ar, vdev_id, addr, peer_type);
Ben Greear479398b2013-11-04 09:19:34 -0800640 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200641 ath10k_warn(ar, "failed to create wmi peer %pM on vdev %i: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +0200642 addr, vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300643 return ret;
Ben Greear479398b2013-11-04 09:19:34 -0800644 }
Kalle Valo5e3dd152013-06-12 20:52:10 +0300645
646 ret = ath10k_wait_for_peer_created(ar, vdev_id, addr);
Ben Greear479398b2013-11-04 09:19:34 -0800647 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200648 ath10k_warn(ar, "failed to wait for created wmi peer %pM on vdev %i: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +0200649 addr, vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300650 return ret;
Ben Greear479398b2013-11-04 09:19:34 -0800651 }
Michal Kazior292a7532014-11-25 15:16:04 +0100652
Bartosz Markowski0e759f32014-01-02 14:38:33 +0100653 ar->num_peers++;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300654
655 return 0;
656}
657
Kalle Valo5a13e762014-01-20 11:01:46 +0200658static int ath10k_mac_set_kickout(struct ath10k_vif *arvif)
659{
660 struct ath10k *ar = arvif->ar;
661 u32 param;
662 int ret;
663
664 param = ar->wmi.pdev_param->sta_kickout_th;
665 ret = ath10k_wmi_pdev_set_param(ar, param,
666 ATH10K_KICKOUT_THRESHOLD);
667 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200668 ath10k_warn(ar, "failed to set kickout threshold on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200669 arvif->vdev_id, ret);
Kalle Valo5a13e762014-01-20 11:01:46 +0200670 return ret;
671 }
672
673 param = ar->wmi.vdev_param->ap_keepalive_min_idle_inactive_time_secs;
674 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, param,
675 ATH10K_KEEPALIVE_MIN_IDLE);
676 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200677 ath10k_warn(ar, "failed to set keepalive minimum idle time on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200678 arvif->vdev_id, ret);
Kalle Valo5a13e762014-01-20 11:01:46 +0200679 return ret;
680 }
681
682 param = ar->wmi.vdev_param->ap_keepalive_max_idle_inactive_time_secs;
683 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, param,
684 ATH10K_KEEPALIVE_MAX_IDLE);
685 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200686 ath10k_warn(ar, "failed to set keepalive maximum idle time on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200687 arvif->vdev_id, ret);
Kalle Valo5a13e762014-01-20 11:01:46 +0200688 return ret;
689 }
690
691 param = ar->wmi.vdev_param->ap_keepalive_max_unresponsive_time_secs;
692 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, param,
693 ATH10K_KEEPALIVE_MAX_UNRESPONSIVE);
694 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200695 ath10k_warn(ar, "failed to set keepalive maximum unresponsive time on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200696 arvif->vdev_id, ret);
Kalle Valo5a13e762014-01-20 11:01:46 +0200697 return ret;
698 }
699
700 return 0;
701}
702
Vivek Natarajanacab6402014-11-26 09:06:12 +0200703static int ath10k_mac_set_rts(struct ath10k_vif *arvif, u32 value)
Michal Kazior424121c2013-07-22 14:13:31 +0200704{
Bartosz Markowski6d1506e2013-09-26 17:47:15 +0200705 struct ath10k *ar = arvif->ar;
706 u32 vdev_param;
707
Bartosz Markowski6d1506e2013-09-26 17:47:15 +0200708 vdev_param = ar->wmi.vdev_param->rts_threshold;
709 return ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param, value);
Michal Kazior424121c2013-07-22 14:13:31 +0200710}
711
Kalle Valo5e3dd152013-06-12 20:52:10 +0300712static int ath10k_peer_delete(struct ath10k *ar, u32 vdev_id, const u8 *addr)
713{
714 int ret;
715
716 lockdep_assert_held(&ar->conf_mutex);
717
718 ret = ath10k_wmi_peer_delete(ar, vdev_id, addr);
719 if (ret)
720 return ret;
721
722 ret = ath10k_wait_for_peer_deleted(ar, vdev_id, addr);
723 if (ret)
724 return ret;
725
Bartosz Markowski0e759f32014-01-02 14:38:33 +0100726 ar->num_peers--;
Bartosz Markowski0e759f32014-01-02 14:38:33 +0100727
Kalle Valo5e3dd152013-06-12 20:52:10 +0300728 return 0;
729}
730
731static void ath10k_peer_cleanup(struct ath10k *ar, u32 vdev_id)
732{
733 struct ath10k_peer *peer, *tmp;
734
735 lockdep_assert_held(&ar->conf_mutex);
736
737 spin_lock_bh(&ar->data_lock);
738 list_for_each_entry_safe(peer, tmp, &ar->peers, list) {
739 if (peer->vdev_id != vdev_id)
740 continue;
741
Michal Kazior7aa7a722014-08-25 12:09:38 +0200742 ath10k_warn(ar, "removing stale peer %pM from vdev_id %d\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +0300743 peer->addr, vdev_id);
744
745 list_del(&peer->list);
746 kfree(peer);
Bartosz Markowski0e759f32014-01-02 14:38:33 +0100747 ar->num_peers--;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300748 }
749 spin_unlock_bh(&ar->data_lock);
750}
751
Michal Kaziora96d7742013-07-16 09:38:56 +0200752static void ath10k_peer_cleanup_all(struct ath10k *ar)
753{
754 struct ath10k_peer *peer, *tmp;
755
756 lockdep_assert_held(&ar->conf_mutex);
757
758 spin_lock_bh(&ar->data_lock);
759 list_for_each_entry_safe(peer, tmp, &ar->peers, list) {
760 list_del(&peer->list);
761 kfree(peer);
762 }
763 spin_unlock_bh(&ar->data_lock);
Michal Kazior292a7532014-11-25 15:16:04 +0100764
765 ar->num_peers = 0;
Michal Kaziorcfd10612014-11-25 15:16:05 +0100766 ar->num_stations = 0;
Michal Kaziora96d7742013-07-16 09:38:56 +0200767}
768
Marek Puzyniak75d85fd2015-03-30 09:51:53 +0300769static int ath10k_mac_tdls_peer_update(struct ath10k *ar, u32 vdev_id,
770 struct ieee80211_sta *sta,
771 enum wmi_tdls_peer_state state)
772{
773 int ret;
774 struct wmi_tdls_peer_update_cmd_arg arg = {};
775 struct wmi_tdls_peer_capab_arg cap = {};
776 struct wmi_channel_arg chan_arg = {};
777
778 lockdep_assert_held(&ar->conf_mutex);
779
780 arg.vdev_id = vdev_id;
781 arg.peer_state = state;
782 ether_addr_copy(arg.addr, sta->addr);
783
784 cap.peer_max_sp = sta->max_sp;
785 cap.peer_uapsd_queues = sta->uapsd_queues;
786
787 if (state == WMI_TDLS_PEER_STATE_CONNECTED &&
788 !sta->tdls_initiator)
789 cap.is_peer_responder = 1;
790
791 ret = ath10k_wmi_tdls_peer_update(ar, &arg, &cap, &chan_arg);
792 if (ret) {
793 ath10k_warn(ar, "failed to update tdls peer %pM on vdev %i: %i\n",
794 arg.addr, vdev_id, ret);
795 return ret;
796 }
797
798 return 0;
799}
800
Kalle Valo5e3dd152013-06-12 20:52:10 +0300801/************************/
802/* Interface management */
803/************************/
804
Michal Kazior64badcb2014-09-18 11:18:02 +0300805void ath10k_mac_vif_beacon_free(struct ath10k_vif *arvif)
806{
807 struct ath10k *ar = arvif->ar;
808
809 lockdep_assert_held(&ar->data_lock);
810
811 if (!arvif->beacon)
812 return;
813
814 if (!arvif->beacon_buf)
815 dma_unmap_single(ar->dev, ATH10K_SKB_CB(arvif->beacon)->paddr,
816 arvif->beacon->len, DMA_TO_DEVICE);
817
Michal Kazioraf213192015-01-29 14:29:52 +0200818 if (WARN_ON(arvif->beacon_state != ATH10K_BEACON_SCHEDULED &&
819 arvif->beacon_state != ATH10K_BEACON_SENT))
820 return;
821
Michal Kazior64badcb2014-09-18 11:18:02 +0300822 dev_kfree_skb_any(arvif->beacon);
823
824 arvif->beacon = NULL;
Michal Kazioraf213192015-01-29 14:29:52 +0200825 arvif->beacon_state = ATH10K_BEACON_SCHEDULED;
Michal Kazior64badcb2014-09-18 11:18:02 +0300826}
827
828static void ath10k_mac_vif_beacon_cleanup(struct ath10k_vif *arvif)
829{
830 struct ath10k *ar = arvif->ar;
831
832 lockdep_assert_held(&ar->data_lock);
833
834 ath10k_mac_vif_beacon_free(arvif);
835
836 if (arvif->beacon_buf) {
837 dma_free_coherent(ar->dev, IEEE80211_MAX_FRAME_LEN,
838 arvif->beacon_buf, arvif->beacon_paddr);
839 arvif->beacon_buf = NULL;
840 }
841}
842
Kalle Valo5e3dd152013-06-12 20:52:10 +0300843static inline int ath10k_vdev_setup_sync(struct ath10k *ar)
844{
Nicholas Mc Guire8e9904f52015-03-30 15:39:19 +0300845 unsigned long time_left;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300846
Michal Kazior548db542013-07-05 16:15:15 +0300847 lockdep_assert_held(&ar->conf_mutex);
848
Michal Kazior7962b0d2014-10-28 10:34:38 +0100849 if (test_bit(ATH10K_FLAG_CRASH_FLUSH, &ar->dev_flags))
850 return -ESHUTDOWN;
851
Nicholas Mc Guire8e9904f52015-03-30 15:39:19 +0300852 time_left = wait_for_completion_timeout(&ar->vdev_setup_done,
853 ATH10K_VDEV_SETUP_TIMEOUT_HZ);
854 if (time_left == 0)
Kalle Valo5e3dd152013-06-12 20:52:10 +0300855 return -ETIMEDOUT;
856
857 return 0;
858}
859
Michal Kazior1bbc0972014-04-08 09:45:47 +0300860static int ath10k_monitor_vdev_start(struct ath10k *ar, int vdev_id)
Kalle Valo5e3dd152013-06-12 20:52:10 +0300861{
Michal Kazior500ff9f2015-03-31 10:26:21 +0000862 struct cfg80211_chan_def *chandef = NULL;
Maninder Singh19be9e92015-07-16 09:25:33 +0530863 struct ieee80211_channel *channel = NULL;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300864 struct wmi_vdev_start_request_arg arg = {};
Kalle Valo5e3dd152013-06-12 20:52:10 +0300865 int ret = 0;
866
867 lockdep_assert_held(&ar->conf_mutex);
868
Michal Kazior500ff9f2015-03-31 10:26:21 +0000869 ieee80211_iter_chan_contexts_atomic(ar->hw,
870 ath10k_mac_get_any_chandef_iter,
871 &chandef);
872 if (WARN_ON_ONCE(!chandef))
873 return -ENOENT;
874
875 channel = chandef->chan;
876
Kalle Valo5e3dd152013-06-12 20:52:10 +0300877 arg.vdev_id = vdev_id;
878 arg.channel.freq = channel->center_freq;
Michal Kaziorc930f742014-01-23 11:38:25 +0100879 arg.channel.band_center_freq1 = chandef->center_freq1;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300880
881 /* TODO setup this dynamically, what in case we
882 don't have any vifs? */
Michal Kaziorc930f742014-01-23 11:38:25 +0100883 arg.channel.mode = chan_to_phymode(chandef);
Marek Puzyniake8a50f82013-11-20 09:59:47 +0200884 arg.channel.chan_radar =
885 !!(channel->flags & IEEE80211_CHAN_RADAR);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300886
Michal Kazior89c5c842013-10-23 04:02:13 -0700887 arg.channel.min_power = 0;
Michal Kazior02256932013-10-23 04:02:14 -0700888 arg.channel.max_power = channel->max_power * 2;
889 arg.channel.max_reg_power = channel->max_reg_power * 2;
890 arg.channel.max_antenna_gain = channel->max_antenna_gain * 2;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300891
Michal Kazior7962b0d2014-10-28 10:34:38 +0100892 reinit_completion(&ar->vdev_setup_done);
893
Kalle Valo5e3dd152013-06-12 20:52:10 +0300894 ret = ath10k_wmi_vdev_start(ar, &arg);
895 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200896 ath10k_warn(ar, "failed to request monitor vdev %i start: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200897 vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300898 return ret;
899 }
900
901 ret = ath10k_vdev_setup_sync(ar);
902 if (ret) {
Ben Greear60028a82015-02-15 16:50:39 +0200903 ath10k_warn(ar, "failed to synchronize setup for monitor vdev %i start: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200904 vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300905 return ret;
906 }
907
908 ret = ath10k_wmi_vdev_up(ar, vdev_id, 0, ar->mac_addr);
909 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200910 ath10k_warn(ar, "failed to put up monitor vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200911 vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300912 goto vdev_stop;
913 }
914
915 ar->monitor_vdev_id = vdev_id;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300916
Michal Kazior7aa7a722014-08-25 12:09:38 +0200917 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac monitor vdev %i started\n",
Michal Kazior1bbc0972014-04-08 09:45:47 +0300918 ar->monitor_vdev_id);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300919 return 0;
920
921vdev_stop:
922 ret = ath10k_wmi_vdev_stop(ar, ar->monitor_vdev_id);
923 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +0200924 ath10k_warn(ar, "failed to stop monitor vdev %i after start failure: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200925 ar->monitor_vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300926
927 return ret;
928}
929
Michal Kazior1bbc0972014-04-08 09:45:47 +0300930static int ath10k_monitor_vdev_stop(struct ath10k *ar)
Kalle Valo5e3dd152013-06-12 20:52:10 +0300931{
932 int ret = 0;
933
934 lockdep_assert_held(&ar->conf_mutex);
935
Marek Puzyniak52fa0192013-09-24 14:06:24 +0200936 ret = ath10k_wmi_vdev_down(ar, ar->monitor_vdev_id);
937 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +0200938 ath10k_warn(ar, "failed to put down monitor vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200939 ar->monitor_vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300940
Michal Kazior7962b0d2014-10-28 10:34:38 +0100941 reinit_completion(&ar->vdev_setup_done);
942
Kalle Valo5e3dd152013-06-12 20:52:10 +0300943 ret = ath10k_wmi_vdev_stop(ar, ar->monitor_vdev_id);
944 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +0200945 ath10k_warn(ar, "failed to to request monitor vdev %i stop: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200946 ar->monitor_vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300947
948 ret = ath10k_vdev_setup_sync(ar);
949 if (ret)
Ben Greear60028a82015-02-15 16:50:39 +0200950 ath10k_warn(ar, "failed to synchronize monitor vdev %i stop: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200951 ar->monitor_vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300952
Michal Kazior7aa7a722014-08-25 12:09:38 +0200953 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac monitor vdev %i stopped\n",
Michal Kazior1bbc0972014-04-08 09:45:47 +0300954 ar->monitor_vdev_id);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300955 return ret;
956}
957
Michal Kazior1bbc0972014-04-08 09:45:47 +0300958static int ath10k_monitor_vdev_create(struct ath10k *ar)
Kalle Valo5e3dd152013-06-12 20:52:10 +0300959{
960 int bit, ret = 0;
961
962 lockdep_assert_held(&ar->conf_mutex);
963
Ben Greeara9aefb32014-08-12 11:02:19 +0300964 if (ar->free_vdev_map == 0) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200965 ath10k_warn(ar, "failed to find free vdev id for monitor vdev\n");
Kalle Valo5e3dd152013-06-12 20:52:10 +0300966 return -ENOMEM;
967 }
968
Ben Greear16c11172014-09-23 14:17:16 -0700969 bit = __ffs64(ar->free_vdev_map);
Ben Greeara9aefb32014-08-12 11:02:19 +0300970
Ben Greear16c11172014-09-23 14:17:16 -0700971 ar->monitor_vdev_id = bit;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300972
973 ret = ath10k_wmi_vdev_create(ar, ar->monitor_vdev_id,
974 WMI_VDEV_TYPE_MONITOR,
975 0, ar->mac_addr);
976 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200977 ath10k_warn(ar, "failed to request monitor vdev %i creation: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200978 ar->monitor_vdev_id, ret);
Ben Greeara9aefb32014-08-12 11:02:19 +0300979 return ret;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300980 }
981
Ben Greear16c11172014-09-23 14:17:16 -0700982 ar->free_vdev_map &= ~(1LL << ar->monitor_vdev_id);
Michal Kazior7aa7a722014-08-25 12:09:38 +0200983 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac monitor vdev %d created\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +0300984 ar->monitor_vdev_id);
985
Kalle Valo5e3dd152013-06-12 20:52:10 +0300986 return 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +0300987}
988
Michal Kazior1bbc0972014-04-08 09:45:47 +0300989static int ath10k_monitor_vdev_delete(struct ath10k *ar)
Kalle Valo5e3dd152013-06-12 20:52:10 +0300990{
991 int ret = 0;
992
993 lockdep_assert_held(&ar->conf_mutex);
994
Kalle Valo5e3dd152013-06-12 20:52:10 +0300995 ret = ath10k_wmi_vdev_delete(ar, ar->monitor_vdev_id);
996 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +0200997 ath10k_warn(ar, "failed to request wmi monitor vdev %i removal: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +0200998 ar->monitor_vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +0300999 return ret;
1000 }
1001
Ben Greear16c11172014-09-23 14:17:16 -07001002 ar->free_vdev_map |= 1LL << ar->monitor_vdev_id;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001003
Michal Kazior7aa7a722014-08-25 12:09:38 +02001004 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac monitor vdev %d deleted\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03001005 ar->monitor_vdev_id);
1006 return ret;
1007}
1008
Michal Kazior1bbc0972014-04-08 09:45:47 +03001009static int ath10k_monitor_start(struct ath10k *ar)
1010{
1011 int ret;
1012
1013 lockdep_assert_held(&ar->conf_mutex);
1014
Michal Kazior1bbc0972014-04-08 09:45:47 +03001015 ret = ath10k_monitor_vdev_create(ar);
1016 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001017 ath10k_warn(ar, "failed to create monitor vdev: %d\n", ret);
Michal Kazior1bbc0972014-04-08 09:45:47 +03001018 return ret;
1019 }
1020
1021 ret = ath10k_monitor_vdev_start(ar, ar->monitor_vdev_id);
1022 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001023 ath10k_warn(ar, "failed to start monitor vdev: %d\n", ret);
Michal Kazior1bbc0972014-04-08 09:45:47 +03001024 ath10k_monitor_vdev_delete(ar);
1025 return ret;
1026 }
1027
1028 ar->monitor_started = true;
Michal Kazior7aa7a722014-08-25 12:09:38 +02001029 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac monitor started\n");
Michal Kazior1bbc0972014-04-08 09:45:47 +03001030
1031 return 0;
1032}
1033
Michal Kazior19337472014-08-28 12:58:16 +02001034static int ath10k_monitor_stop(struct ath10k *ar)
Michal Kazior1bbc0972014-04-08 09:45:47 +03001035{
1036 int ret;
1037
1038 lockdep_assert_held(&ar->conf_mutex);
1039
Michal Kazior1bbc0972014-04-08 09:45:47 +03001040 ret = ath10k_monitor_vdev_stop(ar);
Michal Kazior19337472014-08-28 12:58:16 +02001041 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001042 ath10k_warn(ar, "failed to stop monitor vdev: %d\n", ret);
Michal Kazior19337472014-08-28 12:58:16 +02001043 return ret;
1044 }
Michal Kazior1bbc0972014-04-08 09:45:47 +03001045
1046 ret = ath10k_monitor_vdev_delete(ar);
Michal Kazior19337472014-08-28 12:58:16 +02001047 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001048 ath10k_warn(ar, "failed to delete monitor vdev: %d\n", ret);
Michal Kazior19337472014-08-28 12:58:16 +02001049 return ret;
1050 }
Michal Kazior1bbc0972014-04-08 09:45:47 +03001051
1052 ar->monitor_started = false;
Michal Kazior7aa7a722014-08-25 12:09:38 +02001053 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac monitor stopped\n");
Michal Kazior19337472014-08-28 12:58:16 +02001054
1055 return 0;
1056}
1057
Michal Kazior500ff9f2015-03-31 10:26:21 +00001058static bool ath10k_mac_monitor_vdev_is_needed(struct ath10k *ar)
1059{
1060 int num_ctx;
1061
1062 /* At least one chanctx is required to derive a channel to start
1063 * monitor vdev on.
1064 */
1065 num_ctx = ath10k_mac_num_chanctxs(ar);
1066 if (num_ctx == 0)
1067 return false;
1068
1069 /* If there's already an existing special monitor interface then don't
1070 * bother creating another monitor vdev.
1071 */
1072 if (ar->monitor_arvif)
1073 return false;
1074
1075 return ar->monitor ||
Bob Copeland0d031c82015-09-09 12:47:34 -04001076 ar->filter_flags & FIF_OTHER_BSS ||
Michal Kazior500ff9f2015-03-31 10:26:21 +00001077 test_bit(ATH10K_CAC_RUNNING, &ar->dev_flags);
1078}
1079
1080static bool ath10k_mac_monitor_vdev_is_allowed(struct ath10k *ar)
1081{
1082 int num_ctx;
1083
1084 num_ctx = ath10k_mac_num_chanctxs(ar);
1085
1086 /* FIXME: Current interface combinations and cfg80211/mac80211 code
1087 * shouldn't allow this but make sure to prevent handling the following
1088 * case anyway since multi-channel DFS hasn't been tested at all.
1089 */
1090 if (test_bit(ATH10K_CAC_RUNNING, &ar->dev_flags) && num_ctx > 1)
1091 return false;
1092
1093 return true;
1094}
1095
Michal Kazior19337472014-08-28 12:58:16 +02001096static int ath10k_monitor_recalc(struct ath10k *ar)
1097{
Michal Kazior500ff9f2015-03-31 10:26:21 +00001098 bool needed;
1099 bool allowed;
1100 int ret;
Michal Kazior19337472014-08-28 12:58:16 +02001101
1102 lockdep_assert_held(&ar->conf_mutex);
1103
Michal Kazior500ff9f2015-03-31 10:26:21 +00001104 needed = ath10k_mac_monitor_vdev_is_needed(ar);
1105 allowed = ath10k_mac_monitor_vdev_is_allowed(ar);
Michal Kazior19337472014-08-28 12:58:16 +02001106
1107 ath10k_dbg(ar, ATH10K_DBG_MAC,
Michal Kazior500ff9f2015-03-31 10:26:21 +00001108 "mac monitor recalc started? %d needed? %d allowed? %d\n",
1109 ar->monitor_started, needed, allowed);
Michal Kazior19337472014-08-28 12:58:16 +02001110
Michal Kazior500ff9f2015-03-31 10:26:21 +00001111 if (WARN_ON(needed && !allowed)) {
1112 if (ar->monitor_started) {
1113 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac monitor stopping disallowed monitor\n");
1114
1115 ret = ath10k_monitor_stop(ar);
1116 if (ret)
Kalle Valo2a995082015-10-05 17:56:37 +03001117 ath10k_warn(ar, "failed to stop disallowed monitor: %d\n",
1118 ret);
Michal Kazior500ff9f2015-03-31 10:26:21 +00001119 /* not serious */
1120 }
1121
1122 return -EPERM;
1123 }
1124
1125 if (needed == ar->monitor_started)
Michal Kazior19337472014-08-28 12:58:16 +02001126 return 0;
1127
Michal Kazior500ff9f2015-03-31 10:26:21 +00001128 if (needed)
Michal Kazior19337472014-08-28 12:58:16 +02001129 return ath10k_monitor_start(ar);
Michal Kazior500ff9f2015-03-31 10:26:21 +00001130 else
1131 return ath10k_monitor_stop(ar);
Michal Kazior1bbc0972014-04-08 09:45:47 +03001132}
1133
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02001134static int ath10k_recalc_rtscts_prot(struct ath10k_vif *arvif)
1135{
1136 struct ath10k *ar = arvif->ar;
1137 u32 vdev_param, rts_cts = 0;
1138
1139 lockdep_assert_held(&ar->conf_mutex);
1140
1141 vdev_param = ar->wmi.vdev_param->enable_rtscts;
1142
Rajkumar Manoharan9a5ab0f2015-03-19 16:03:29 +02001143 rts_cts |= SM(WMI_RTSCTS_ENABLED, WMI_RTSCTS_SET);
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02001144
1145 if (arvif->num_legacy_stations > 0)
1146 rts_cts |= SM(WMI_RTSCTS_ACROSS_SW_RETRIES,
1147 WMI_RTSCTS_PROFILE);
Rajkumar Manoharan9a5ab0f2015-03-19 16:03:29 +02001148 else
1149 rts_cts |= SM(WMI_RTSCTS_FOR_SECOND_RATESERIES,
1150 WMI_RTSCTS_PROFILE);
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02001151
1152 return ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
1153 rts_cts);
1154}
1155
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001156static int ath10k_start_cac(struct ath10k *ar)
1157{
1158 int ret;
1159
1160 lockdep_assert_held(&ar->conf_mutex);
1161
1162 set_bit(ATH10K_CAC_RUNNING, &ar->dev_flags);
1163
Michal Kazior19337472014-08-28 12:58:16 +02001164 ret = ath10k_monitor_recalc(ar);
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001165 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001166 ath10k_warn(ar, "failed to start monitor (cac): %d\n", ret);
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001167 clear_bit(ATH10K_CAC_RUNNING, &ar->dev_flags);
1168 return ret;
1169 }
1170
Michal Kazior7aa7a722014-08-25 12:09:38 +02001171 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac cac start monitor vdev %d\n",
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001172 ar->monitor_vdev_id);
1173
1174 return 0;
1175}
1176
1177static int ath10k_stop_cac(struct ath10k *ar)
1178{
1179 lockdep_assert_held(&ar->conf_mutex);
1180
1181 /* CAC is not running - do nothing */
1182 if (!test_bit(ATH10K_CAC_RUNNING, &ar->dev_flags))
1183 return 0;
1184
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001185 clear_bit(ATH10K_CAC_RUNNING, &ar->dev_flags);
Michal Kazior1bbc0972014-04-08 09:45:47 +03001186 ath10k_monitor_stop(ar);
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001187
Michal Kazior7aa7a722014-08-25 12:09:38 +02001188 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac cac finished\n");
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001189
1190 return 0;
1191}
1192
Michal Kazior500ff9f2015-03-31 10:26:21 +00001193static void ath10k_mac_has_radar_iter(struct ieee80211_hw *hw,
1194 struct ieee80211_chanctx_conf *conf,
1195 void *data)
1196{
1197 bool *ret = data;
1198
1199 if (!*ret && conf->radar_enabled)
1200 *ret = true;
1201}
1202
1203static bool ath10k_mac_has_radar_enabled(struct ath10k *ar)
1204{
1205 bool has_radar = false;
1206
1207 ieee80211_iter_chan_contexts_atomic(ar->hw,
1208 ath10k_mac_has_radar_iter,
1209 &has_radar);
1210
1211 return has_radar;
1212}
1213
Michal Kaziord6500972014-04-08 09:56:09 +03001214static void ath10k_recalc_radar_detection(struct ath10k *ar)
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001215{
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001216 int ret;
1217
1218 lockdep_assert_held(&ar->conf_mutex);
1219
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001220 ath10k_stop_cac(ar);
1221
Michal Kazior500ff9f2015-03-31 10:26:21 +00001222 if (!ath10k_mac_has_radar_enabled(ar))
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001223 return;
1224
Michal Kaziord6500972014-04-08 09:56:09 +03001225 if (ar->num_started_vdevs > 0)
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001226 return;
1227
1228 ret = ath10k_start_cac(ar);
1229 if (ret) {
1230 /*
1231 * Not possible to start CAC on current channel so starting
1232 * radiation is not allowed, make this channel DFS_UNAVAILABLE
1233 * by indicating that radar was detected.
1234 */
Michal Kazior7aa7a722014-08-25 12:09:38 +02001235 ath10k_warn(ar, "failed to start CAC: %d\n", ret);
Marek Puzyniake8a50f82013-11-20 09:59:47 +02001236 ieee80211_radar_detected(ar->hw);
1237 }
1238}
1239
Vasanthakumar Thiagarajan822b7e02015-03-02 17:45:27 +05301240static int ath10k_vdev_stop(struct ath10k_vif *arvif)
Michal Kazior72654fa2014-04-08 09:56:09 +03001241{
1242 struct ath10k *ar = arvif->ar;
Vasanthakumar Thiagarajan822b7e02015-03-02 17:45:27 +05301243 int ret;
1244
1245 lockdep_assert_held(&ar->conf_mutex);
1246
1247 reinit_completion(&ar->vdev_setup_done);
1248
1249 ret = ath10k_wmi_vdev_stop(ar, arvif->vdev_id);
1250 if (ret) {
1251 ath10k_warn(ar, "failed to stop WMI vdev %i: %d\n",
1252 arvif->vdev_id, ret);
1253 return ret;
1254 }
1255
1256 ret = ath10k_vdev_setup_sync(ar);
1257 if (ret) {
1258 ath10k_warn(ar, "failed to syncronise setup for vdev %i: %d\n",
1259 arvif->vdev_id, ret);
1260 return ret;
1261 }
1262
1263 WARN_ON(ar->num_started_vdevs == 0);
1264
1265 if (ar->num_started_vdevs != 0) {
1266 ar->num_started_vdevs--;
1267 ath10k_recalc_radar_detection(ar);
1268 }
1269
1270 return ret;
1271}
1272
Michal Kazior500ff9f2015-03-31 10:26:21 +00001273static int ath10k_vdev_start_restart(struct ath10k_vif *arvif,
1274 const struct cfg80211_chan_def *chandef,
1275 bool restart)
Michal Kazior72654fa2014-04-08 09:56:09 +03001276{
1277 struct ath10k *ar = arvif->ar;
Michal Kazior72654fa2014-04-08 09:56:09 +03001278 struct wmi_vdev_start_request_arg arg = {};
1279 int ret = 0;
1280
1281 lockdep_assert_held(&ar->conf_mutex);
1282
1283 reinit_completion(&ar->vdev_setup_done);
1284
1285 arg.vdev_id = arvif->vdev_id;
1286 arg.dtim_period = arvif->dtim_period;
1287 arg.bcn_intval = arvif->beacon_interval;
1288
1289 arg.channel.freq = chandef->chan->center_freq;
1290 arg.channel.band_center_freq1 = chandef->center_freq1;
1291 arg.channel.mode = chan_to_phymode(chandef);
1292
1293 arg.channel.min_power = 0;
1294 arg.channel.max_power = chandef->chan->max_power * 2;
1295 arg.channel.max_reg_power = chandef->chan->max_reg_power * 2;
1296 arg.channel.max_antenna_gain = chandef->chan->max_antenna_gain * 2;
1297
1298 if (arvif->vdev_type == WMI_VDEV_TYPE_AP) {
1299 arg.ssid = arvif->u.ap.ssid;
1300 arg.ssid_len = arvif->u.ap.ssid_len;
1301 arg.hidden_ssid = arvif->u.ap.hidden_ssid;
1302
1303 /* For now allow DFS for AP mode */
1304 arg.channel.chan_radar =
1305 !!(chandef->chan->flags & IEEE80211_CHAN_RADAR);
1306 } else if (arvif->vdev_type == WMI_VDEV_TYPE_IBSS) {
1307 arg.ssid = arvif->vif->bss_conf.ssid;
1308 arg.ssid_len = arvif->vif->bss_conf.ssid_len;
1309 }
1310
Michal Kazior7aa7a722014-08-25 12:09:38 +02001311 ath10k_dbg(ar, ATH10K_DBG_MAC,
Michal Kazior72654fa2014-04-08 09:56:09 +03001312 "mac vdev %d start center_freq %d phymode %s\n",
1313 arg.vdev_id, arg.channel.freq,
1314 ath10k_wmi_phymode_str(arg.channel.mode));
1315
Michal Kaziordc55e302014-07-29 12:53:36 +03001316 if (restart)
1317 ret = ath10k_wmi_vdev_restart(ar, &arg);
1318 else
1319 ret = ath10k_wmi_vdev_start(ar, &arg);
1320
Michal Kazior72654fa2014-04-08 09:56:09 +03001321 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001322 ath10k_warn(ar, "failed to start WMI vdev %i: %d\n",
Michal Kazior72654fa2014-04-08 09:56:09 +03001323 arg.vdev_id, ret);
1324 return ret;
1325 }
1326
1327 ret = ath10k_vdev_setup_sync(ar);
1328 if (ret) {
Ben Greear60028a82015-02-15 16:50:39 +02001329 ath10k_warn(ar,
1330 "failed to synchronize setup for vdev %i restart %d: %d\n",
1331 arg.vdev_id, restart, ret);
Michal Kazior72654fa2014-04-08 09:56:09 +03001332 return ret;
1333 }
1334
Michal Kaziord6500972014-04-08 09:56:09 +03001335 ar->num_started_vdevs++;
1336 ath10k_recalc_radar_detection(ar);
1337
Michal Kazior72654fa2014-04-08 09:56:09 +03001338 return ret;
1339}
1340
Michal Kazior500ff9f2015-03-31 10:26:21 +00001341static int ath10k_vdev_start(struct ath10k_vif *arvif,
1342 const struct cfg80211_chan_def *def)
Michal Kaziordc55e302014-07-29 12:53:36 +03001343{
Michal Kazior500ff9f2015-03-31 10:26:21 +00001344 return ath10k_vdev_start_restart(arvif, def, false);
Michal Kaziordc55e302014-07-29 12:53:36 +03001345}
1346
Michal Kazior500ff9f2015-03-31 10:26:21 +00001347static int ath10k_vdev_restart(struct ath10k_vif *arvif,
1348 const struct cfg80211_chan_def *def)
Michal Kaziordc55e302014-07-29 12:53:36 +03001349{
Michal Kazior500ff9f2015-03-31 10:26:21 +00001350 return ath10k_vdev_start_restart(arvif, def, true);
Michal Kazior72654fa2014-04-08 09:56:09 +03001351}
1352
Michal Kaziorfbb8f1b2015-01-13 16:30:12 +02001353static int ath10k_mac_setup_bcn_p2p_ie(struct ath10k_vif *arvif,
1354 struct sk_buff *bcn)
1355{
1356 struct ath10k *ar = arvif->ar;
1357 struct ieee80211_mgmt *mgmt;
1358 const u8 *p2p_ie;
1359 int ret;
1360
1361 if (arvif->vdev_type != WMI_VDEV_TYPE_AP)
1362 return 0;
1363
1364 if (arvif->vdev_subtype != WMI_VDEV_SUBTYPE_P2P_GO)
1365 return 0;
1366
1367 mgmt = (void *)bcn->data;
1368 p2p_ie = cfg80211_find_vendor_ie(WLAN_OUI_WFA, WLAN_OUI_TYPE_WFA_P2P,
1369 mgmt->u.beacon.variable,
1370 bcn->len - (mgmt->u.beacon.variable -
1371 bcn->data));
1372 if (!p2p_ie)
1373 return -ENOENT;
1374
1375 ret = ath10k_wmi_p2p_go_bcn_ie(ar, arvif->vdev_id, p2p_ie);
1376 if (ret) {
1377 ath10k_warn(ar, "failed to submit p2p go bcn ie for vdev %i: %d\n",
1378 arvif->vdev_id, ret);
1379 return ret;
1380 }
1381
1382 return 0;
1383}
1384
1385static int ath10k_mac_remove_vendor_ie(struct sk_buff *skb, unsigned int oui,
1386 u8 oui_type, size_t ie_offset)
1387{
1388 size_t len;
1389 const u8 *next;
1390 const u8 *end;
1391 u8 *ie;
1392
1393 if (WARN_ON(skb->len < ie_offset))
1394 return -EINVAL;
1395
1396 ie = (u8 *)cfg80211_find_vendor_ie(oui, oui_type,
1397 skb->data + ie_offset,
1398 skb->len - ie_offset);
1399 if (!ie)
1400 return -ENOENT;
1401
1402 len = ie[1] + 2;
1403 end = skb->data + skb->len;
1404 next = ie + len;
1405
1406 if (WARN_ON(next > end))
1407 return -EINVAL;
1408
1409 memmove(ie, next, end - next);
1410 skb_trim(skb, skb->len - len);
1411
1412 return 0;
1413}
1414
1415static int ath10k_mac_setup_bcn_tmpl(struct ath10k_vif *arvif)
1416{
1417 struct ath10k *ar = arvif->ar;
1418 struct ieee80211_hw *hw = ar->hw;
1419 struct ieee80211_vif *vif = arvif->vif;
1420 struct ieee80211_mutable_offsets offs = {};
1421 struct sk_buff *bcn;
1422 int ret;
1423
1424 if (!test_bit(WMI_SERVICE_BEACON_OFFLOAD, ar->wmi.svc_map))
1425 return 0;
1426
Michal Kazior81a9a172015-03-05 16:02:17 +02001427 if (arvif->vdev_type != WMI_VDEV_TYPE_AP &&
1428 arvif->vdev_type != WMI_VDEV_TYPE_IBSS)
1429 return 0;
1430
Michal Kaziorfbb8f1b2015-01-13 16:30:12 +02001431 bcn = ieee80211_beacon_get_template(hw, vif, &offs);
1432 if (!bcn) {
1433 ath10k_warn(ar, "failed to get beacon template from mac80211\n");
1434 return -EPERM;
1435 }
1436
1437 ret = ath10k_mac_setup_bcn_p2p_ie(arvif, bcn);
1438 if (ret) {
1439 ath10k_warn(ar, "failed to setup p2p go bcn ie: %d\n", ret);
1440 kfree_skb(bcn);
1441 return ret;
1442 }
1443
1444 /* P2P IE is inserted by firmware automatically (as configured above)
1445 * so remove it from the base beacon template to avoid duplicate P2P
1446 * IEs in beacon frames.
1447 */
1448 ath10k_mac_remove_vendor_ie(bcn, WLAN_OUI_WFA, WLAN_OUI_TYPE_WFA_P2P,
1449 offsetof(struct ieee80211_mgmt,
1450 u.beacon.variable));
1451
1452 ret = ath10k_wmi_bcn_tmpl(ar, arvif->vdev_id, offs.tim_offset, bcn, 0,
1453 0, NULL, 0);
1454 kfree_skb(bcn);
1455
1456 if (ret) {
1457 ath10k_warn(ar, "failed to submit beacon template command: %d\n",
1458 ret);
1459 return ret;
1460 }
1461
1462 return 0;
1463}
1464
1465static int ath10k_mac_setup_prb_tmpl(struct ath10k_vif *arvif)
1466{
1467 struct ath10k *ar = arvif->ar;
1468 struct ieee80211_hw *hw = ar->hw;
1469 struct ieee80211_vif *vif = arvif->vif;
1470 struct sk_buff *prb;
1471 int ret;
1472
1473 if (!test_bit(WMI_SERVICE_BEACON_OFFLOAD, ar->wmi.svc_map))
1474 return 0;
1475
Michal Kazior81a9a172015-03-05 16:02:17 +02001476 if (arvif->vdev_type != WMI_VDEV_TYPE_AP)
1477 return 0;
1478
Michal Kaziorfbb8f1b2015-01-13 16:30:12 +02001479 prb = ieee80211_proberesp_get(hw, vif);
1480 if (!prb) {
1481 ath10k_warn(ar, "failed to get probe resp template from mac80211\n");
1482 return -EPERM;
1483 }
1484
1485 ret = ath10k_wmi_prb_tmpl(ar, arvif->vdev_id, prb);
1486 kfree_skb(prb);
1487
1488 if (ret) {
1489 ath10k_warn(ar, "failed to submit probe resp template command: %d\n",
1490 ret);
1491 return ret;
1492 }
1493
1494 return 0;
1495}
1496
Michal Kazior500ff9f2015-03-31 10:26:21 +00001497static int ath10k_mac_vif_fix_hidden_ssid(struct ath10k_vif *arvif)
1498{
1499 struct ath10k *ar = arvif->ar;
1500 struct cfg80211_chan_def def;
1501 int ret;
1502
1503 /* When originally vdev is started during assign_vif_chanctx() some
1504 * information is missing, notably SSID. Firmware revisions with beacon
1505 * offloading require the SSID to be provided during vdev (re)start to
1506 * handle hidden SSID properly.
1507 *
1508 * Vdev restart must be done after vdev has been both started and
1509 * upped. Otherwise some firmware revisions (at least 10.2) fail to
1510 * deliver vdev restart response event causing timeouts during vdev
1511 * syncing in ath10k.
1512 *
1513 * Note: The vdev down/up and template reinstallation could be skipped
1514 * since only wmi-tlv firmware are known to have beacon offload and
1515 * wmi-tlv doesn't seem to misbehave like 10.2 wrt vdev restart
1516 * response delivery. It's probably more robust to keep it as is.
1517 */
1518 if (!test_bit(WMI_SERVICE_BEACON_OFFLOAD, ar->wmi.svc_map))
1519 return 0;
1520
1521 if (WARN_ON(!arvif->is_started))
1522 return -EINVAL;
1523
1524 if (WARN_ON(!arvif->is_up))
1525 return -EINVAL;
1526
1527 if (WARN_ON(ath10k_mac_vif_chan(arvif->vif, &def)))
1528 return -EINVAL;
1529
1530 ret = ath10k_wmi_vdev_down(ar, arvif->vdev_id);
1531 if (ret) {
1532 ath10k_warn(ar, "failed to bring down ap vdev %i: %d\n",
1533 arvif->vdev_id, ret);
1534 return ret;
1535 }
1536
1537 /* Vdev down reset beacon & presp templates. Reinstall them. Otherwise
1538 * firmware will crash upon vdev up.
1539 */
1540
1541 ret = ath10k_mac_setup_bcn_tmpl(arvif);
1542 if (ret) {
1543 ath10k_warn(ar, "failed to update beacon template: %d\n", ret);
1544 return ret;
1545 }
1546
1547 ret = ath10k_mac_setup_prb_tmpl(arvif);
1548 if (ret) {
1549 ath10k_warn(ar, "failed to update presp template: %d\n", ret);
1550 return ret;
1551 }
1552
1553 ret = ath10k_vdev_restart(arvif, &def);
1554 if (ret) {
1555 ath10k_warn(ar, "failed to restart ap vdev %i: %d\n",
1556 arvif->vdev_id, ret);
1557 return ret;
1558 }
1559
1560 ret = ath10k_wmi_vdev_up(arvif->ar, arvif->vdev_id, arvif->aid,
1561 arvif->bssid);
1562 if (ret) {
1563 ath10k_warn(ar, "failed to bring up ap vdev %i: %d\n",
1564 arvif->vdev_id, ret);
1565 return ret;
1566 }
1567
1568 return 0;
1569}
1570
Kalle Valo5e3dd152013-06-12 20:52:10 +03001571static void ath10k_control_beaconing(struct ath10k_vif *arvif,
Kalle Valo5b07e072014-09-14 12:50:06 +03001572 struct ieee80211_bss_conf *info)
Kalle Valo5e3dd152013-06-12 20:52:10 +03001573{
Michal Kazior7aa7a722014-08-25 12:09:38 +02001574 struct ath10k *ar = arvif->ar;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001575 int ret = 0;
1576
Michal Kazior548db542013-07-05 16:15:15 +03001577 lockdep_assert_held(&arvif->ar->conf_mutex);
1578
Kalle Valo5e3dd152013-06-12 20:52:10 +03001579 if (!info->enable_beacon) {
Michal Kazior500ff9f2015-03-31 10:26:21 +00001580 ret = ath10k_wmi_vdev_down(ar, arvif->vdev_id);
1581 if (ret)
1582 ath10k_warn(ar, "failed to down vdev_id %i: %d\n",
1583 arvif->vdev_id, ret);
Michal Kaziorc930f742014-01-23 11:38:25 +01001584
Michal Kaziorc930f742014-01-23 11:38:25 +01001585 arvif->is_up = false;
1586
Michal Kazior748afc42014-01-23 12:48:21 +01001587 spin_lock_bh(&arvif->ar->data_lock);
Michal Kazior64badcb2014-09-18 11:18:02 +03001588 ath10k_mac_vif_beacon_free(arvif);
Michal Kazior748afc42014-01-23 12:48:21 +01001589 spin_unlock_bh(&arvif->ar->data_lock);
1590
Kalle Valo5e3dd152013-06-12 20:52:10 +03001591 return;
1592 }
1593
1594 arvif->tx_seq_no = 0x1000;
1595
Michal Kaziorc930f742014-01-23 11:38:25 +01001596 arvif->aid = 0;
Kalle Valob25f32c2014-09-14 12:50:49 +03001597 ether_addr_copy(arvif->bssid, info->bssid);
Michal Kaziorc930f742014-01-23 11:38:25 +01001598
1599 ret = ath10k_wmi_vdev_up(arvif->ar, arvif->vdev_id, arvif->aid,
1600 arvif->bssid);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001601 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001602 ath10k_warn(ar, "failed to bring up vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02001603 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001604 return;
1605 }
Michal Kaziorc930f742014-01-23 11:38:25 +01001606
Michal Kaziorc930f742014-01-23 11:38:25 +01001607 arvif->is_up = true;
1608
Michal Kazior500ff9f2015-03-31 10:26:21 +00001609 ret = ath10k_mac_vif_fix_hidden_ssid(arvif);
1610 if (ret) {
1611 ath10k_warn(ar, "failed to fix hidden ssid for vdev %i, expect trouble: %d\n",
1612 arvif->vdev_id, ret);
1613 return;
1614 }
1615
Michal Kazior7aa7a722014-08-25 12:09:38 +02001616 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %d up\n", arvif->vdev_id);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001617}
1618
1619static void ath10k_control_ibss(struct ath10k_vif *arvif,
1620 struct ieee80211_bss_conf *info,
1621 const u8 self_peer[ETH_ALEN])
1622{
Michal Kazior7aa7a722014-08-25 12:09:38 +02001623 struct ath10k *ar = arvif->ar;
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02001624 u32 vdev_param;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001625 int ret = 0;
1626
Michal Kazior548db542013-07-05 16:15:15 +03001627 lockdep_assert_held(&arvif->ar->conf_mutex);
1628
Kalle Valo5e3dd152013-06-12 20:52:10 +03001629 if (!info->ibss_joined) {
Michal Kaziorc930f742014-01-23 11:38:25 +01001630 if (is_zero_ether_addr(arvif->bssid))
Kalle Valo5e3dd152013-06-12 20:52:10 +03001631 return;
1632
Joe Perches93803b32015-03-02 19:54:49 -08001633 eth_zero_addr(arvif->bssid);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001634
1635 return;
1636 }
1637
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02001638 vdev_param = arvif->ar->wmi.vdev_param->atim_window;
1639 ret = ath10k_wmi_vdev_set_param(arvif->ar, arvif->vdev_id, vdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03001640 ATH10K_DEFAULT_ATIM);
1641 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02001642 ath10k_warn(ar, "failed to set IBSS ATIM for vdev %d: %d\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03001643 arvif->vdev_id, ret);
1644}
1645
Michal Kazior9f9b5742014-12-12 12:41:36 +01001646static int ath10k_mac_vif_recalc_ps_wake_threshold(struct ath10k_vif *arvif)
1647{
1648 struct ath10k *ar = arvif->ar;
1649 u32 param;
1650 u32 value;
1651 int ret;
1652
1653 lockdep_assert_held(&arvif->ar->conf_mutex);
1654
1655 if (arvif->u.sta.uapsd)
1656 value = WMI_STA_PS_TX_WAKE_THRESHOLD_NEVER;
1657 else
1658 value = WMI_STA_PS_TX_WAKE_THRESHOLD_ALWAYS;
1659
1660 param = WMI_STA_PS_PARAM_TX_WAKE_THRESHOLD;
1661 ret = ath10k_wmi_set_sta_ps_param(ar, arvif->vdev_id, param, value);
1662 if (ret) {
1663 ath10k_warn(ar, "failed to submit ps wake threshold %u on vdev %i: %d\n",
1664 value, arvif->vdev_id, ret);
1665 return ret;
1666 }
1667
1668 return 0;
1669}
1670
1671static int ath10k_mac_vif_recalc_ps_poll_count(struct ath10k_vif *arvif)
1672{
1673 struct ath10k *ar = arvif->ar;
1674 u32 param;
1675 u32 value;
1676 int ret;
1677
1678 lockdep_assert_held(&arvif->ar->conf_mutex);
1679
1680 if (arvif->u.sta.uapsd)
1681 value = WMI_STA_PS_PSPOLL_COUNT_UAPSD;
1682 else
1683 value = WMI_STA_PS_PSPOLL_COUNT_NO_MAX;
1684
1685 param = WMI_STA_PS_PARAM_PSPOLL_COUNT;
1686 ret = ath10k_wmi_set_sta_ps_param(ar, arvif->vdev_id,
1687 param, value);
1688 if (ret) {
1689 ath10k_warn(ar, "failed to submit ps poll count %u on vdev %i: %d\n",
1690 value, arvif->vdev_id, ret);
1691 return ret;
1692 }
1693
1694 return 0;
1695}
1696
Michal Kazior424f2632015-07-09 13:08:35 +02001697static int ath10k_mac_num_vifs_started(struct ath10k *ar)
Michal Kaziorcffb41f2015-02-13 13:30:16 +01001698{
1699 struct ath10k_vif *arvif;
1700 int num = 0;
1701
1702 lockdep_assert_held(&ar->conf_mutex);
1703
1704 list_for_each_entry(arvif, &ar->arvifs, list)
Michal Kazior424f2632015-07-09 13:08:35 +02001705 if (arvif->is_started)
Michal Kaziorcffb41f2015-02-13 13:30:16 +01001706 num++;
1707
1708 return num;
1709}
1710
Michal Kaziorad088bf2013-10-16 15:44:46 +03001711static int ath10k_mac_vif_setup_ps(struct ath10k_vif *arvif)
Kalle Valo5e3dd152013-06-12 20:52:10 +03001712{
Michal Kaziorad088bf2013-10-16 15:44:46 +03001713 struct ath10k *ar = arvif->ar;
Michal Kazior526549a2014-12-12 12:41:37 +01001714 struct ieee80211_vif *vif = arvif->vif;
Michal Kaziorad088bf2013-10-16 15:44:46 +03001715 struct ieee80211_conf *conf = &ar->hw->conf;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001716 enum wmi_sta_powersave_param param;
1717 enum wmi_sta_ps_mode psmode;
1718 int ret;
Michal Kazior526549a2014-12-12 12:41:37 +01001719 int ps_timeout;
Michal Kaziorcffb41f2015-02-13 13:30:16 +01001720 bool enable_ps;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001721
Michal Kazior548db542013-07-05 16:15:15 +03001722 lockdep_assert_held(&arvif->ar->conf_mutex);
1723
Michal Kaziorad088bf2013-10-16 15:44:46 +03001724 if (arvif->vif->type != NL80211_IFTYPE_STATION)
1725 return 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001726
Michal Kaziorcffb41f2015-02-13 13:30:16 +01001727 enable_ps = arvif->ps;
1728
Michal Kazior424f2632015-07-09 13:08:35 +02001729 if (enable_ps && ath10k_mac_num_vifs_started(ar) > 1 &&
Michal Kaziorcffb41f2015-02-13 13:30:16 +01001730 !test_bit(ATH10K_FW_FEATURE_MULTI_VIF_PS_SUPPORT,
1731 ar->fw_features)) {
1732 ath10k_warn(ar, "refusing to enable ps on vdev %i: not supported by fw\n",
1733 arvif->vdev_id);
1734 enable_ps = false;
1735 }
1736
Janusz Dziedzic917826b2015-05-18 09:38:17 +00001737 if (!arvif->is_started) {
1738 /* mac80211 can update vif powersave state while disconnected.
1739 * Firmware doesn't behave nicely and consumes more power than
1740 * necessary if PS is disabled on a non-started vdev. Hence
1741 * force-enable PS for non-running vdevs.
1742 */
1743 psmode = WMI_STA_PS_MODE_ENABLED;
1744 } else if (enable_ps) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03001745 psmode = WMI_STA_PS_MODE_ENABLED;
1746 param = WMI_STA_PS_PARAM_INACTIVITY_TIME;
1747
Michal Kazior526549a2014-12-12 12:41:37 +01001748 ps_timeout = conf->dynamic_ps_timeout;
1749 if (ps_timeout == 0) {
1750 /* Firmware doesn't like 0 */
1751 ps_timeout = ieee80211_tu_to_usec(
1752 vif->bss_conf.beacon_int) / 1000;
1753 }
1754
Michal Kaziorad088bf2013-10-16 15:44:46 +03001755 ret = ath10k_wmi_set_sta_ps_param(ar, arvif->vdev_id, param,
Michal Kazior526549a2014-12-12 12:41:37 +01001756 ps_timeout);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001757 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001758 ath10k_warn(ar, "failed to set inactivity time for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02001759 arvif->vdev_id, ret);
Michal Kaziorad088bf2013-10-16 15:44:46 +03001760 return ret;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001761 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03001762 } else {
1763 psmode = WMI_STA_PS_MODE_DISABLED;
1764 }
1765
Michal Kazior7aa7a722014-08-25 12:09:38 +02001766 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %d psmode %s\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03001767 arvif->vdev_id, psmode ? "enable" : "disable");
1768
Michal Kaziorad088bf2013-10-16 15:44:46 +03001769 ret = ath10k_wmi_set_psmode(ar, arvif->vdev_id, psmode);
1770 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02001771 ath10k_warn(ar, "failed to set PS Mode %d for vdev %d: %d\n",
Kalle Valobe6546f2014-03-25 14:18:51 +02001772 psmode, arvif->vdev_id, ret);
Michal Kaziorad088bf2013-10-16 15:44:46 +03001773 return ret;
1774 }
1775
1776 return 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001777}
1778
Michal Kazior46725b152015-01-28 09:57:49 +02001779static int ath10k_mac_vif_disable_keepalive(struct ath10k_vif *arvif)
1780{
1781 struct ath10k *ar = arvif->ar;
1782 struct wmi_sta_keepalive_arg arg = {};
1783 int ret;
1784
1785 lockdep_assert_held(&arvif->ar->conf_mutex);
1786
1787 if (arvif->vdev_type != WMI_VDEV_TYPE_STA)
1788 return 0;
1789
1790 if (!test_bit(WMI_SERVICE_STA_KEEP_ALIVE, ar->wmi.svc_map))
1791 return 0;
1792
1793 /* Some firmware revisions have a bug and ignore the `enabled` field.
1794 * Instead use the interval to disable the keepalive.
1795 */
1796 arg.vdev_id = arvif->vdev_id;
1797 arg.enabled = 1;
1798 arg.method = WMI_STA_KEEPALIVE_METHOD_NULL_FRAME;
1799 arg.interval = WMI_STA_KEEPALIVE_INTERVAL_DISABLE;
1800
1801 ret = ath10k_wmi_sta_keepalive(ar, &arg);
1802 if (ret) {
1803 ath10k_warn(ar, "failed to submit keepalive on vdev %i: %d\n",
1804 arvif->vdev_id, ret);
1805 return ret;
1806 }
1807
1808 return 0;
1809}
1810
Michal Kazior81a9a172015-03-05 16:02:17 +02001811static void ath10k_mac_vif_ap_csa_count_down(struct ath10k_vif *arvif)
1812{
1813 struct ath10k *ar = arvif->ar;
1814 struct ieee80211_vif *vif = arvif->vif;
1815 int ret;
1816
Michal Kazior8513d952015-03-09 14:19:24 +01001817 lockdep_assert_held(&arvif->ar->conf_mutex);
1818
1819 if (WARN_ON(!test_bit(WMI_SERVICE_BEACON_OFFLOAD, ar->wmi.svc_map)))
1820 return;
1821
Michal Kazior81a9a172015-03-05 16:02:17 +02001822 if (arvif->vdev_type != WMI_VDEV_TYPE_AP)
1823 return;
1824
1825 if (!vif->csa_active)
1826 return;
1827
1828 if (!arvif->is_up)
1829 return;
1830
1831 if (!ieee80211_csa_is_complete(vif)) {
1832 ieee80211_csa_update_counter(vif);
1833
1834 ret = ath10k_mac_setup_bcn_tmpl(arvif);
1835 if (ret)
1836 ath10k_warn(ar, "failed to update bcn tmpl during csa: %d\n",
1837 ret);
1838
1839 ret = ath10k_mac_setup_prb_tmpl(arvif);
1840 if (ret)
1841 ath10k_warn(ar, "failed to update prb tmpl during csa: %d\n",
1842 ret);
1843 } else {
1844 ieee80211_csa_finish(vif);
1845 }
1846}
1847
1848static void ath10k_mac_vif_ap_csa_work(struct work_struct *work)
1849{
1850 struct ath10k_vif *arvif = container_of(work, struct ath10k_vif,
1851 ap_csa_work);
1852 struct ath10k *ar = arvif->ar;
1853
1854 mutex_lock(&ar->conf_mutex);
1855 ath10k_mac_vif_ap_csa_count_down(arvif);
1856 mutex_unlock(&ar->conf_mutex);
1857}
1858
Michal Kaziorcc9904e2015-03-10 16:22:01 +02001859static void ath10k_mac_handle_beacon_iter(void *data, u8 *mac,
1860 struct ieee80211_vif *vif)
1861{
1862 struct sk_buff *skb = data;
1863 struct ieee80211_mgmt *mgmt = (void *)skb->data;
1864 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
1865
1866 if (vif->type != NL80211_IFTYPE_STATION)
1867 return;
1868
1869 if (!ether_addr_equal(mgmt->bssid, vif->bss_conf.bssid))
1870 return;
1871
1872 cancel_delayed_work(&arvif->connection_loss_work);
1873}
1874
1875void ath10k_mac_handle_beacon(struct ath10k *ar, struct sk_buff *skb)
1876{
1877 ieee80211_iterate_active_interfaces_atomic(ar->hw,
1878 IEEE80211_IFACE_ITER_NORMAL,
1879 ath10k_mac_handle_beacon_iter,
1880 skb);
1881}
1882
1883static void ath10k_mac_handle_beacon_miss_iter(void *data, u8 *mac,
1884 struct ieee80211_vif *vif)
1885{
1886 u32 *vdev_id = data;
1887 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
1888 struct ath10k *ar = arvif->ar;
1889 struct ieee80211_hw *hw = ar->hw;
1890
1891 if (arvif->vdev_id != *vdev_id)
1892 return;
1893
1894 if (!arvif->is_up)
1895 return;
1896
1897 ieee80211_beacon_loss(vif);
1898
1899 /* Firmware doesn't report beacon loss events repeatedly. If AP probe
1900 * (done by mac80211) succeeds but beacons do not resume then it
1901 * doesn't make sense to continue operation. Queue connection loss work
1902 * which can be cancelled when beacon is received.
1903 */
1904 ieee80211_queue_delayed_work(hw, &arvif->connection_loss_work,
1905 ATH10K_CONNECTION_LOSS_HZ);
1906}
1907
1908void ath10k_mac_handle_beacon_miss(struct ath10k *ar, u32 vdev_id)
1909{
1910 ieee80211_iterate_active_interfaces_atomic(ar->hw,
1911 IEEE80211_IFACE_ITER_NORMAL,
1912 ath10k_mac_handle_beacon_miss_iter,
1913 &vdev_id);
1914}
1915
1916static void ath10k_mac_vif_sta_connection_loss_work(struct work_struct *work)
1917{
1918 struct ath10k_vif *arvif = container_of(work, struct ath10k_vif,
1919 connection_loss_work.work);
1920 struct ieee80211_vif *vif = arvif->vif;
1921
1922 if (!arvif->is_up)
1923 return;
1924
1925 ieee80211_connection_loss(vif);
1926}
1927
Kalle Valo5e3dd152013-06-12 20:52:10 +03001928/**********************/
1929/* Station management */
1930/**********************/
1931
Michal Kazior590922a2014-10-21 10:10:29 +03001932static u32 ath10k_peer_assoc_h_listen_intval(struct ath10k *ar,
1933 struct ieee80211_vif *vif)
1934{
1935 /* Some firmware revisions have unstable STA powersave when listen
1936 * interval is set too high (e.g. 5). The symptoms are firmware doesn't
1937 * generate NullFunc frames properly even if buffered frames have been
1938 * indicated in Beacon TIM. Firmware would seldom wake up to pull
1939 * buffered frames. Often pinging the device from AP would simply fail.
1940 *
1941 * As a workaround set it to 1.
1942 */
1943 if (vif->type == NL80211_IFTYPE_STATION)
1944 return 1;
1945
1946 return ar->hw->conf.listen_interval;
1947}
1948
Kalle Valo5e3dd152013-06-12 20:52:10 +03001949static void ath10k_peer_assoc_h_basic(struct ath10k *ar,
Michal Kazior590922a2014-10-21 10:10:29 +03001950 struct ieee80211_vif *vif,
Kalle Valo5e3dd152013-06-12 20:52:10 +03001951 struct ieee80211_sta *sta,
Kalle Valo5e3dd152013-06-12 20:52:10 +03001952 struct wmi_peer_assoc_complete_arg *arg)
1953{
Michal Kazior590922a2014-10-21 10:10:29 +03001954 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kaziorc51880e2015-03-30 09:51:57 +03001955 u32 aid;
Michal Kazior590922a2014-10-21 10:10:29 +03001956
Michal Kazior548db542013-07-05 16:15:15 +03001957 lockdep_assert_held(&ar->conf_mutex);
1958
Michal Kaziorc51880e2015-03-30 09:51:57 +03001959 if (vif->type == NL80211_IFTYPE_STATION)
1960 aid = vif->bss_conf.aid;
1961 else
1962 aid = sta->aid;
1963
Kalle Valob25f32c2014-09-14 12:50:49 +03001964 ether_addr_copy(arg->addr, sta->addr);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001965 arg->vdev_id = arvif->vdev_id;
Michal Kaziorc51880e2015-03-30 09:51:57 +03001966 arg->peer_aid = aid;
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02001967 arg->peer_flags |= arvif->ar->wmi.peer_flags->auth;
Michal Kazior590922a2014-10-21 10:10:29 +03001968 arg->peer_listen_intval = ath10k_peer_assoc_h_listen_intval(ar, vif);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001969 arg->peer_num_spatial_streams = 1;
Michal Kazior590922a2014-10-21 10:10:29 +03001970 arg->peer_caps = vif->bss_conf.assoc_capability;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001971}
1972
1973static void ath10k_peer_assoc_h_crypto(struct ath10k *ar,
Michal Kazior590922a2014-10-21 10:10:29 +03001974 struct ieee80211_vif *vif,
Tamizh chelvam90eceb32015-10-29 14:27:42 +02001975 struct ieee80211_sta *sta,
Kalle Valo5e3dd152013-06-12 20:52:10 +03001976 struct wmi_peer_assoc_complete_arg *arg)
1977{
Kalle Valo5e3dd152013-06-12 20:52:10 +03001978 struct ieee80211_bss_conf *info = &vif->bss_conf;
Michal Kazior500ff9f2015-03-31 10:26:21 +00001979 struct cfg80211_chan_def def;
Kalle Valo5e3dd152013-06-12 20:52:10 +03001980 struct cfg80211_bss *bss;
1981 const u8 *rsnie = NULL;
1982 const u8 *wpaie = NULL;
1983
Michal Kazior548db542013-07-05 16:15:15 +03001984 lockdep_assert_held(&ar->conf_mutex);
1985
Michal Kazior500ff9f2015-03-31 10:26:21 +00001986 if (WARN_ON(ath10k_mac_vif_chan(vif, &def)))
1987 return;
1988
1989 bss = cfg80211_get_bss(ar->hw->wiphy, def.chan, info->bssid, NULL, 0,
1990 IEEE80211_BSS_TYPE_ANY, IEEE80211_PRIVACY_ANY);
Kalle Valo5e3dd152013-06-12 20:52:10 +03001991 if (bss) {
1992 const struct cfg80211_bss_ies *ies;
1993
1994 rcu_read_lock();
1995 rsnie = ieee80211_bss_get_ie(bss, WLAN_EID_RSN);
1996
1997 ies = rcu_dereference(bss->ies);
1998
1999 wpaie = cfg80211_find_vendor_ie(WLAN_OUI_MICROSOFT,
Kalle Valo5b07e072014-09-14 12:50:06 +03002000 WLAN_OUI_TYPE_MICROSOFT_WPA,
2001 ies->data,
2002 ies->len);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002003 rcu_read_unlock();
2004 cfg80211_put_bss(ar->hw->wiphy, bss);
2005 }
2006
2007 /* FIXME: base on RSN IE/WPA IE is a correct idea? */
2008 if (rsnie || wpaie) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002009 ath10k_dbg(ar, ATH10K_DBG_WMI, "%s: rsn ie found\n", __func__);
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002010 arg->peer_flags |= ar->wmi.peer_flags->need_ptk_4_way;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002011 }
2012
2013 if (wpaie) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002014 ath10k_dbg(ar, ATH10K_DBG_WMI, "%s: wpa ie found\n", __func__);
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002015 arg->peer_flags |= ar->wmi.peer_flags->need_gtk_2_way;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002016 }
Tamizh chelvam90eceb32015-10-29 14:27:42 +02002017
2018 if (sta->mfp &&
2019 test_bit(ATH10K_FW_FEATURE_MFP_SUPPORT, ar->fw_features)) {
2020 arg->peer_flags |= ar->wmi.peer_flags->pmf;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002021 }
2022}
2023
2024static void ath10k_peer_assoc_h_rates(struct ath10k *ar,
Michal Kazior500ff9f2015-03-31 10:26:21 +00002025 struct ieee80211_vif *vif,
Kalle Valo5e3dd152013-06-12 20:52:10 +03002026 struct ieee80211_sta *sta,
2027 struct wmi_peer_assoc_complete_arg *arg)
2028{
Michal Kazior45c9abc2015-04-21 20:42:58 +03002029 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002030 struct wmi_rate_set_arg *rateset = &arg->peer_legacy_rates;
Michal Kazior500ff9f2015-03-31 10:26:21 +00002031 struct cfg80211_chan_def def;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002032 const struct ieee80211_supported_band *sband;
2033 const struct ieee80211_rate *rates;
Michal Kazior45c9abc2015-04-21 20:42:58 +03002034 enum ieee80211_band band;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002035 u32 ratemask;
Michal Kazior486017c2015-03-30 09:51:54 +03002036 u8 rate;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002037 int i;
2038
Michal Kazior548db542013-07-05 16:15:15 +03002039 lockdep_assert_held(&ar->conf_mutex);
2040
Michal Kazior500ff9f2015-03-31 10:26:21 +00002041 if (WARN_ON(ath10k_mac_vif_chan(vif, &def)))
2042 return;
2043
Michal Kazior45c9abc2015-04-21 20:42:58 +03002044 band = def.chan->band;
2045 sband = ar->hw->wiphy->bands[band];
2046 ratemask = sta->supp_rates[band];
2047 ratemask &= arvif->bitrate_mask.control[band].legacy;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002048 rates = sband->bitrates;
2049
2050 rateset->num_rates = 0;
2051
2052 for (i = 0; i < 32; i++, ratemask >>= 1, rates++) {
2053 if (!(ratemask & 1))
2054 continue;
2055
Michal Kazior486017c2015-03-30 09:51:54 +03002056 rate = ath10k_mac_bitrate_to_rate(rates->bitrate);
2057 rateset->rates[rateset->num_rates] = rate;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002058 rateset->num_rates++;
2059 }
2060}
2061
Michal Kazior45c9abc2015-04-21 20:42:58 +03002062static bool
2063ath10k_peer_assoc_h_ht_masked(const u8 ht_mcs_mask[IEEE80211_HT_MCS_MASK_LEN])
2064{
2065 int nss;
2066
2067 for (nss = 0; nss < IEEE80211_HT_MCS_MASK_LEN; nss++)
2068 if (ht_mcs_mask[nss])
2069 return false;
2070
2071 return true;
2072}
2073
2074static bool
2075ath10k_peer_assoc_h_vht_masked(const u16 vht_mcs_mask[NL80211_VHT_NSS_MAX])
2076{
2077 int nss;
2078
2079 for (nss = 0; nss < NL80211_VHT_NSS_MAX; nss++)
2080 if (vht_mcs_mask[nss])
2081 return false;
2082
2083 return true;
2084}
2085
Kalle Valo5e3dd152013-06-12 20:52:10 +03002086static void ath10k_peer_assoc_h_ht(struct ath10k *ar,
Michal Kazior45c9abc2015-04-21 20:42:58 +03002087 struct ieee80211_vif *vif,
Kalle Valo5e3dd152013-06-12 20:52:10 +03002088 struct ieee80211_sta *sta,
2089 struct wmi_peer_assoc_complete_arg *arg)
2090{
2091 const struct ieee80211_sta_ht_cap *ht_cap = &sta->ht_cap;
Michal Kazior45c9abc2015-04-21 20:42:58 +03002092 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
2093 struct cfg80211_chan_def def;
2094 enum ieee80211_band band;
2095 const u8 *ht_mcs_mask;
2096 const u16 *vht_mcs_mask;
Vivek Natarajan72f8cef2015-10-06 15:19:34 +03002097 int i, n;
2098 u8 max_nss;
Kalle Valoaf762c02014-09-14 12:50:17 +03002099 u32 stbc;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002100
Michal Kazior548db542013-07-05 16:15:15 +03002101 lockdep_assert_held(&ar->conf_mutex);
2102
Michal Kazior45c9abc2015-04-21 20:42:58 +03002103 if (WARN_ON(ath10k_mac_vif_chan(vif, &def)))
2104 return;
2105
Kalle Valo5e3dd152013-06-12 20:52:10 +03002106 if (!ht_cap->ht_supported)
2107 return;
2108
Michal Kazior45c9abc2015-04-21 20:42:58 +03002109 band = def.chan->band;
2110 ht_mcs_mask = arvif->bitrate_mask.control[band].ht_mcs;
2111 vht_mcs_mask = arvif->bitrate_mask.control[band].vht_mcs;
2112
2113 if (ath10k_peer_assoc_h_ht_masked(ht_mcs_mask) &&
2114 ath10k_peer_assoc_h_vht_masked(vht_mcs_mask))
2115 return;
2116
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002117 arg->peer_flags |= ar->wmi.peer_flags->ht;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002118 arg->peer_max_mpdu = (1 << (IEEE80211_HT_MAX_AMPDU_FACTOR +
2119 ht_cap->ampdu_factor)) - 1;
2120
2121 arg->peer_mpdu_density =
2122 ath10k_parse_mpdudensity(ht_cap->ampdu_density);
2123
2124 arg->peer_ht_caps = ht_cap->cap;
2125 arg->peer_rate_caps |= WMI_RC_HT_FLAG;
2126
2127 if (ht_cap->cap & IEEE80211_HT_CAP_LDPC_CODING)
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002128 arg->peer_flags |= ar->wmi.peer_flags->ldbc;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002129
2130 if (sta->bandwidth >= IEEE80211_STA_RX_BW_40) {
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002131 arg->peer_flags |= ar->wmi.peer_flags->bw40;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002132 arg->peer_rate_caps |= WMI_RC_CW40_FLAG;
2133 }
2134
Michal Kazior45c9abc2015-04-21 20:42:58 +03002135 if (arvif->bitrate_mask.control[band].gi != NL80211_TXRATE_FORCE_LGI) {
2136 if (ht_cap->cap & IEEE80211_HT_CAP_SGI_20)
2137 arg->peer_rate_caps |= WMI_RC_SGI_FLAG;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002138
Michal Kazior45c9abc2015-04-21 20:42:58 +03002139 if (ht_cap->cap & IEEE80211_HT_CAP_SGI_40)
2140 arg->peer_rate_caps |= WMI_RC_SGI_FLAG;
2141 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002142
2143 if (ht_cap->cap & IEEE80211_HT_CAP_TX_STBC) {
2144 arg->peer_rate_caps |= WMI_RC_TX_STBC_FLAG;
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002145 arg->peer_flags |= ar->wmi.peer_flags->stbc;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002146 }
2147
2148 if (ht_cap->cap & IEEE80211_HT_CAP_RX_STBC) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03002149 stbc = ht_cap->cap & IEEE80211_HT_CAP_RX_STBC;
2150 stbc = stbc >> IEEE80211_HT_CAP_RX_STBC_SHIFT;
2151 stbc = stbc << WMI_RC_RX_STBC_FLAG_S;
2152 arg->peer_rate_caps |= stbc;
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002153 arg->peer_flags |= ar->wmi.peer_flags->stbc;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002154 }
2155
Kalle Valo5e3dd152013-06-12 20:52:10 +03002156 if (ht_cap->mcs.rx_mask[1] && ht_cap->mcs.rx_mask[2])
2157 arg->peer_rate_caps |= WMI_RC_TS_FLAG;
2158 else if (ht_cap->mcs.rx_mask[1])
2159 arg->peer_rate_caps |= WMI_RC_DS_FLAG;
2160
Michal Kazior45c9abc2015-04-21 20:42:58 +03002161 for (i = 0, n = 0, max_nss = 0; i < IEEE80211_HT_MCS_MASK_LEN * 8; i++)
2162 if ((ht_cap->mcs.rx_mask[i / 8] & BIT(i % 8)) &&
2163 (ht_mcs_mask[i / 8] & BIT(i % 8))) {
2164 max_nss = (i / 8) + 1;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002165 arg->peer_ht_rates.rates[n++] = i;
Michal Kazior45c9abc2015-04-21 20:42:58 +03002166 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002167
Bartosz Markowskifd71f802014-02-10 13:12:55 +01002168 /*
2169 * This is a workaround for HT-enabled STAs which break the spec
2170 * and have no HT capabilities RX mask (no HT RX MCS map).
2171 *
2172 * As per spec, in section 20.3.5 Modulation and coding scheme (MCS),
2173 * MCS 0 through 7 are mandatory in 20MHz with 800 ns GI at all STAs.
2174 *
2175 * Firmware asserts if such situation occurs.
2176 */
2177 if (n == 0) {
2178 arg->peer_ht_rates.num_rates = 8;
2179 for (i = 0; i < arg->peer_ht_rates.num_rates; i++)
2180 arg->peer_ht_rates.rates[i] = i;
2181 } else {
2182 arg->peer_ht_rates.num_rates = n;
Vivek Natarajan72f8cef2015-10-06 15:19:34 +03002183 arg->peer_num_spatial_streams = min(sta->rx_nss, max_nss);
Bartosz Markowskifd71f802014-02-10 13:12:55 +01002184 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002185
Michal Kazior7aa7a722014-08-25 12:09:38 +02002186 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac ht peer %pM mcs cnt %d nss %d\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03002187 arg->addr,
Kalle Valo5e3dd152013-06-12 20:52:10 +03002188 arg->peer_ht_rates.num_rates,
2189 arg->peer_num_spatial_streams);
2190}
2191
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002192static int ath10k_peer_assoc_qos_ap(struct ath10k *ar,
2193 struct ath10k_vif *arvif,
2194 struct ieee80211_sta *sta)
Kalle Valo5e3dd152013-06-12 20:52:10 +03002195{
2196 u32 uapsd = 0;
2197 u32 max_sp = 0;
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002198 int ret = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002199
Michal Kazior548db542013-07-05 16:15:15 +03002200 lockdep_assert_held(&ar->conf_mutex);
2201
Kalle Valo5e3dd152013-06-12 20:52:10 +03002202 if (sta->wme && sta->uapsd_queues) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002203 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac uapsd_queues 0x%x max_sp %d\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03002204 sta->uapsd_queues, sta->max_sp);
2205
Kalle Valo5e3dd152013-06-12 20:52:10 +03002206 if (sta->uapsd_queues & IEEE80211_WMM_IE_STA_QOSINFO_AC_VO)
2207 uapsd |= WMI_AP_PS_UAPSD_AC3_DELIVERY_EN |
2208 WMI_AP_PS_UAPSD_AC3_TRIGGER_EN;
2209 if (sta->uapsd_queues & IEEE80211_WMM_IE_STA_QOSINFO_AC_VI)
2210 uapsd |= WMI_AP_PS_UAPSD_AC2_DELIVERY_EN |
2211 WMI_AP_PS_UAPSD_AC2_TRIGGER_EN;
2212 if (sta->uapsd_queues & IEEE80211_WMM_IE_STA_QOSINFO_AC_BK)
2213 uapsd |= WMI_AP_PS_UAPSD_AC1_DELIVERY_EN |
2214 WMI_AP_PS_UAPSD_AC1_TRIGGER_EN;
2215 if (sta->uapsd_queues & IEEE80211_WMM_IE_STA_QOSINFO_AC_BE)
2216 uapsd |= WMI_AP_PS_UAPSD_AC0_DELIVERY_EN |
2217 WMI_AP_PS_UAPSD_AC0_TRIGGER_EN;
2218
Kalle Valo5e3dd152013-06-12 20:52:10 +03002219 if (sta->max_sp < MAX_WMI_AP_PS_PEER_PARAM_MAX_SP)
2220 max_sp = sta->max_sp;
2221
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002222 ret = ath10k_wmi_set_ap_ps_param(ar, arvif->vdev_id,
2223 sta->addr,
2224 WMI_AP_PS_PEER_PARAM_UAPSD,
2225 uapsd);
2226 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002227 ath10k_warn(ar, "failed to set ap ps peer param uapsd for vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02002228 arvif->vdev_id, ret);
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002229 return ret;
2230 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002231
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002232 ret = ath10k_wmi_set_ap_ps_param(ar, arvif->vdev_id,
2233 sta->addr,
2234 WMI_AP_PS_PEER_PARAM_MAX_SP,
2235 max_sp);
2236 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002237 ath10k_warn(ar, "failed to set ap ps peer param max sp for vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02002238 arvif->vdev_id, ret);
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002239 return ret;
2240 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002241
2242 /* TODO setup this based on STA listen interval and
2243 beacon interval. Currently we don't know
2244 sta->listen_interval - mac80211 patch required.
2245 Currently use 10 seconds */
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002246 ret = ath10k_wmi_set_ap_ps_param(ar, arvif->vdev_id, sta->addr,
Kalle Valo5b07e072014-09-14 12:50:06 +03002247 WMI_AP_PS_PEER_PARAM_AGEOUT_TIME,
2248 10);
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002249 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002250 ath10k_warn(ar, "failed to set ap ps peer param ageout time for vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02002251 arvif->vdev_id, ret);
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002252 return ret;
2253 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002254 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002255
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002256 return 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002257}
2258
Michal Kazior45c9abc2015-04-21 20:42:58 +03002259static u16
2260ath10k_peer_assoc_h_vht_limit(u16 tx_mcs_set,
2261 const u16 vht_mcs_limit[NL80211_VHT_NSS_MAX])
2262{
2263 int idx_limit;
2264 int nss;
2265 u16 mcs_map;
2266 u16 mcs;
2267
2268 for (nss = 0; nss < NL80211_VHT_NSS_MAX; nss++) {
2269 mcs_map = ath10k_mac_get_max_vht_mcs_map(tx_mcs_set, nss) &
2270 vht_mcs_limit[nss];
2271
2272 if (mcs_map)
2273 idx_limit = fls(mcs_map) - 1;
2274 else
2275 idx_limit = -1;
2276
2277 switch (idx_limit) {
2278 case 0: /* fall through */
2279 case 1: /* fall through */
2280 case 2: /* fall through */
2281 case 3: /* fall through */
2282 case 4: /* fall through */
2283 case 5: /* fall through */
2284 case 6: /* fall through */
2285 default:
2286 /* see ath10k_mac_can_set_bitrate_mask() */
2287 WARN_ON(1);
2288 /* fall through */
2289 case -1:
2290 mcs = IEEE80211_VHT_MCS_NOT_SUPPORTED;
2291 break;
2292 case 7:
2293 mcs = IEEE80211_VHT_MCS_SUPPORT_0_7;
2294 break;
2295 case 8:
2296 mcs = IEEE80211_VHT_MCS_SUPPORT_0_8;
2297 break;
2298 case 9:
2299 mcs = IEEE80211_VHT_MCS_SUPPORT_0_9;
2300 break;
2301 }
2302
2303 tx_mcs_set &= ~(0x3 << (nss * 2));
2304 tx_mcs_set |= mcs << (nss * 2);
2305 }
2306
2307 return tx_mcs_set;
2308}
2309
Kalle Valo5e3dd152013-06-12 20:52:10 +03002310static void ath10k_peer_assoc_h_vht(struct ath10k *ar,
Michal Kazior500ff9f2015-03-31 10:26:21 +00002311 struct ieee80211_vif *vif,
Kalle Valo5e3dd152013-06-12 20:52:10 +03002312 struct ieee80211_sta *sta,
2313 struct wmi_peer_assoc_complete_arg *arg)
2314{
2315 const struct ieee80211_sta_vht_cap *vht_cap = &sta->vht_cap;
Michal Kazior45c9abc2015-04-21 20:42:58 +03002316 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kazior500ff9f2015-03-31 10:26:21 +00002317 struct cfg80211_chan_def def;
Michal Kazior45c9abc2015-04-21 20:42:58 +03002318 enum ieee80211_band band;
2319 const u16 *vht_mcs_mask;
Sujith Manoharana24b88b2013-10-07 19:51:57 -07002320 u8 ampdu_factor;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002321
Michal Kazior500ff9f2015-03-31 10:26:21 +00002322 if (WARN_ON(ath10k_mac_vif_chan(vif, &def)))
2323 return;
2324
Kalle Valo5e3dd152013-06-12 20:52:10 +03002325 if (!vht_cap->vht_supported)
2326 return;
2327
Michal Kazior45c9abc2015-04-21 20:42:58 +03002328 band = def.chan->band;
2329 vht_mcs_mask = arvif->bitrate_mask.control[band].vht_mcs;
2330
2331 if (ath10k_peer_assoc_h_vht_masked(vht_mcs_mask))
2332 return;
2333
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002334 arg->peer_flags |= ar->wmi.peer_flags->vht;
Yanbo Lid68bb122015-01-23 08:18:20 +08002335
Michal Kazior500ff9f2015-03-31 10:26:21 +00002336 if (def.chan->band == IEEE80211_BAND_2GHZ)
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002337 arg->peer_flags |= ar->wmi.peer_flags->vht_2g;
Yanbo Lid68bb122015-01-23 08:18:20 +08002338
Kalle Valo5e3dd152013-06-12 20:52:10 +03002339 arg->peer_vht_caps = vht_cap->cap;
2340
Sujith Manoharana24b88b2013-10-07 19:51:57 -07002341 ampdu_factor = (vht_cap->cap &
2342 IEEE80211_VHT_CAP_MAX_A_MPDU_LENGTH_EXPONENT_MASK) >>
2343 IEEE80211_VHT_CAP_MAX_A_MPDU_LENGTH_EXPONENT_SHIFT;
2344
2345 /* Workaround: Some Netgear/Linksys 11ac APs set Rx A-MPDU factor to
2346 * zero in VHT IE. Using it would result in degraded throughput.
2347 * arg->peer_max_mpdu at this point contains HT max_mpdu so keep
2348 * it if VHT max_mpdu is smaller. */
2349 arg->peer_max_mpdu = max(arg->peer_max_mpdu,
2350 (1U << (IEEE80211_HT_MAX_AMPDU_FACTOR +
2351 ampdu_factor)) - 1);
2352
Kalle Valo5e3dd152013-06-12 20:52:10 +03002353 if (sta->bandwidth == IEEE80211_STA_RX_BW_80)
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002354 arg->peer_flags |= ar->wmi.peer_flags->bw80;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002355
2356 arg->peer_vht_rates.rx_max_rate =
2357 __le16_to_cpu(vht_cap->vht_mcs.rx_highest);
2358 arg->peer_vht_rates.rx_mcs_set =
2359 __le16_to_cpu(vht_cap->vht_mcs.rx_mcs_map);
2360 arg->peer_vht_rates.tx_max_rate =
2361 __le16_to_cpu(vht_cap->vht_mcs.tx_highest);
Michal Kazior45c9abc2015-04-21 20:42:58 +03002362 arg->peer_vht_rates.tx_mcs_set = ath10k_peer_assoc_h_vht_limit(
2363 __le16_to_cpu(vht_cap->vht_mcs.tx_mcs_map), vht_mcs_mask);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002364
Michal Kazior7aa7a722014-08-25 12:09:38 +02002365 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vht peer %pM max_mpdu %d flags 0x%x\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03002366 sta->addr, arg->peer_max_mpdu, arg->peer_flags);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002367}
2368
2369static void ath10k_peer_assoc_h_qos(struct ath10k *ar,
Michal Kazior590922a2014-10-21 10:10:29 +03002370 struct ieee80211_vif *vif,
Kalle Valo5e3dd152013-06-12 20:52:10 +03002371 struct ieee80211_sta *sta,
Kalle Valo5e3dd152013-06-12 20:52:10 +03002372 struct wmi_peer_assoc_complete_arg *arg)
2373{
Michal Kazior590922a2014-10-21 10:10:29 +03002374 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
2375
Kalle Valo5e3dd152013-06-12 20:52:10 +03002376 switch (arvif->vdev_type) {
2377 case WMI_VDEV_TYPE_AP:
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002378 if (sta->wme)
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002379 arg->peer_flags |= arvif->ar->wmi.peer_flags->qos;
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002380
2381 if (sta->wme && sta->uapsd_queues) {
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002382 arg->peer_flags |= arvif->ar->wmi.peer_flags->apsd;
Janusz Dziedzicd3d3ff42014-01-21 07:06:53 +01002383 arg->peer_rate_caps |= WMI_RC_UAPSD_FLAG;
2384 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002385 break;
2386 case WMI_VDEV_TYPE_STA:
Michal Kazior590922a2014-10-21 10:10:29 +03002387 if (vif->bss_conf.qos)
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002388 arg->peer_flags |= arvif->ar->wmi.peer_flags->qos;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002389 break;
Janusz Dziedzic627d9842014-12-17 12:29:54 +02002390 case WMI_VDEV_TYPE_IBSS:
2391 if (sta->wme)
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002392 arg->peer_flags |= arvif->ar->wmi.peer_flags->qos;
Janusz Dziedzic627d9842014-12-17 12:29:54 +02002393 break;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002394 default:
2395 break;
2396 }
Janusz Dziedzic627d9842014-12-17 12:29:54 +02002397
2398 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac peer %pM qos %d\n",
Tamizh chelvam3fab30f2015-10-29 14:27:37 +02002399 sta->addr, !!(arg->peer_flags &
2400 arvif->ar->wmi.peer_flags->qos));
Kalle Valo5e3dd152013-06-12 20:52:10 +03002401}
2402
Michal Kazior8d7aa6b2015-03-30 09:51:57 +03002403static bool ath10k_mac_sta_has_ofdm_only(struct ieee80211_sta *sta)
Michal Kazior91b12082014-12-12 12:41:35 +01002404{
Michal Kazior8d7aa6b2015-03-30 09:51:57 +03002405 return sta->supp_rates[IEEE80211_BAND_2GHZ] >>
2406 ATH10K_MAC_FIRST_OFDM_RATE_IDX;
Michal Kazior91b12082014-12-12 12:41:35 +01002407}
2408
Kalle Valo5e3dd152013-06-12 20:52:10 +03002409static void ath10k_peer_assoc_h_phymode(struct ath10k *ar,
Michal Kazior590922a2014-10-21 10:10:29 +03002410 struct ieee80211_vif *vif,
Kalle Valo5e3dd152013-06-12 20:52:10 +03002411 struct ieee80211_sta *sta,
2412 struct wmi_peer_assoc_complete_arg *arg)
2413{
Michal Kazior45c9abc2015-04-21 20:42:58 +03002414 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kazior500ff9f2015-03-31 10:26:21 +00002415 struct cfg80211_chan_def def;
Michal Kazior45c9abc2015-04-21 20:42:58 +03002416 enum ieee80211_band band;
2417 const u8 *ht_mcs_mask;
2418 const u16 *vht_mcs_mask;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002419 enum wmi_phy_mode phymode = MODE_UNKNOWN;
2420
Michal Kazior500ff9f2015-03-31 10:26:21 +00002421 if (WARN_ON(ath10k_mac_vif_chan(vif, &def)))
2422 return;
2423
Michal Kazior45c9abc2015-04-21 20:42:58 +03002424 band = def.chan->band;
2425 ht_mcs_mask = arvif->bitrate_mask.control[band].ht_mcs;
2426 vht_mcs_mask = arvif->bitrate_mask.control[band].vht_mcs;
2427
2428 switch (band) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03002429 case IEEE80211_BAND_2GHZ:
Michal Kazior45c9abc2015-04-21 20:42:58 +03002430 if (sta->vht_cap.vht_supported &&
2431 !ath10k_peer_assoc_h_vht_masked(vht_mcs_mask)) {
Yanbo Lid68bb122015-01-23 08:18:20 +08002432 if (sta->bandwidth == IEEE80211_STA_RX_BW_40)
2433 phymode = MODE_11AC_VHT40;
2434 else
2435 phymode = MODE_11AC_VHT20;
Michal Kazior45c9abc2015-04-21 20:42:58 +03002436 } else if (sta->ht_cap.ht_supported &&
2437 !ath10k_peer_assoc_h_ht_masked(ht_mcs_mask)) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03002438 if (sta->bandwidth == IEEE80211_STA_RX_BW_40)
2439 phymode = MODE_11NG_HT40;
2440 else
2441 phymode = MODE_11NG_HT20;
Michal Kazior8d7aa6b2015-03-30 09:51:57 +03002442 } else if (ath10k_mac_sta_has_ofdm_only(sta)) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03002443 phymode = MODE_11G;
Michal Kazior91b12082014-12-12 12:41:35 +01002444 } else {
2445 phymode = MODE_11B;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002446 }
2447
2448 break;
2449 case IEEE80211_BAND_5GHZ:
Sujith Manoharan7cc45e92013-09-08 18:19:55 +03002450 /*
2451 * Check VHT first.
2452 */
Michal Kazior45c9abc2015-04-21 20:42:58 +03002453 if (sta->vht_cap.vht_supported &&
2454 !ath10k_peer_assoc_h_vht_masked(vht_mcs_mask)) {
Sujith Manoharan7cc45e92013-09-08 18:19:55 +03002455 if (sta->bandwidth == IEEE80211_STA_RX_BW_80)
2456 phymode = MODE_11AC_VHT80;
2457 else if (sta->bandwidth == IEEE80211_STA_RX_BW_40)
2458 phymode = MODE_11AC_VHT40;
2459 else if (sta->bandwidth == IEEE80211_STA_RX_BW_20)
2460 phymode = MODE_11AC_VHT20;
Michal Kazior45c9abc2015-04-21 20:42:58 +03002461 } else if (sta->ht_cap.ht_supported &&
2462 !ath10k_peer_assoc_h_ht_masked(ht_mcs_mask)) {
2463 if (sta->bandwidth >= IEEE80211_STA_RX_BW_40)
Kalle Valo5e3dd152013-06-12 20:52:10 +03002464 phymode = MODE_11NA_HT40;
2465 else
2466 phymode = MODE_11NA_HT20;
2467 } else {
2468 phymode = MODE_11A;
2469 }
2470
2471 break;
2472 default:
2473 break;
2474 }
2475
Michal Kazior7aa7a722014-08-25 12:09:38 +02002476 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac peer %pM phymode %s\n",
Kalle Valo38a1d472013-09-08 17:56:14 +03002477 sta->addr, ath10k_wmi_phymode_str(phymode));
Kalle Valo60c3daa2013-09-08 17:56:07 +03002478
Kalle Valo5e3dd152013-06-12 20:52:10 +03002479 arg->peer_phymode = phymode;
2480 WARN_ON(phymode == MODE_UNKNOWN);
2481}
2482
Kalle Valob9ada652013-10-16 15:44:46 +03002483static int ath10k_peer_assoc_prepare(struct ath10k *ar,
Michal Kazior590922a2014-10-21 10:10:29 +03002484 struct ieee80211_vif *vif,
Kalle Valob9ada652013-10-16 15:44:46 +03002485 struct ieee80211_sta *sta,
Kalle Valob9ada652013-10-16 15:44:46 +03002486 struct wmi_peer_assoc_complete_arg *arg)
Kalle Valo5e3dd152013-06-12 20:52:10 +03002487{
Michal Kazior548db542013-07-05 16:15:15 +03002488 lockdep_assert_held(&ar->conf_mutex);
2489
Kalle Valob9ada652013-10-16 15:44:46 +03002490 memset(arg, 0, sizeof(*arg));
Kalle Valo5e3dd152013-06-12 20:52:10 +03002491
Michal Kazior590922a2014-10-21 10:10:29 +03002492 ath10k_peer_assoc_h_basic(ar, vif, sta, arg);
Tamizh chelvam90eceb32015-10-29 14:27:42 +02002493 ath10k_peer_assoc_h_crypto(ar, vif, sta, arg);
Michal Kazior500ff9f2015-03-31 10:26:21 +00002494 ath10k_peer_assoc_h_rates(ar, vif, sta, arg);
Michal Kazior45c9abc2015-04-21 20:42:58 +03002495 ath10k_peer_assoc_h_ht(ar, vif, sta, arg);
Michal Kazior500ff9f2015-03-31 10:26:21 +00002496 ath10k_peer_assoc_h_vht(ar, vif, sta, arg);
Michal Kazior590922a2014-10-21 10:10:29 +03002497 ath10k_peer_assoc_h_qos(ar, vif, sta, arg);
2498 ath10k_peer_assoc_h_phymode(ar, vif, sta, arg);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002499
Kalle Valob9ada652013-10-16 15:44:46 +03002500 return 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002501}
2502
Michal Kazior90046f52014-02-14 14:45:51 +01002503static const u32 ath10k_smps_map[] = {
2504 [WLAN_HT_CAP_SM_PS_STATIC] = WMI_PEER_SMPS_STATIC,
2505 [WLAN_HT_CAP_SM_PS_DYNAMIC] = WMI_PEER_SMPS_DYNAMIC,
2506 [WLAN_HT_CAP_SM_PS_INVALID] = WMI_PEER_SMPS_PS_NONE,
2507 [WLAN_HT_CAP_SM_PS_DISABLED] = WMI_PEER_SMPS_PS_NONE,
2508};
2509
2510static int ath10k_setup_peer_smps(struct ath10k *ar, struct ath10k_vif *arvif,
2511 const u8 *addr,
2512 const struct ieee80211_sta_ht_cap *ht_cap)
2513{
2514 int smps;
2515
2516 if (!ht_cap->ht_supported)
2517 return 0;
2518
2519 smps = ht_cap->cap & IEEE80211_HT_CAP_SM_PS;
2520 smps >>= IEEE80211_HT_CAP_SM_PS_SHIFT;
2521
2522 if (smps >= ARRAY_SIZE(ath10k_smps_map))
2523 return -EINVAL;
2524
2525 return ath10k_wmi_peer_set_param(ar, arvif->vdev_id, addr,
2526 WMI_PEER_SMPS_STATE,
2527 ath10k_smps_map[smps]);
2528}
2529
Michal Kazior139e1702015-02-15 16:50:42 +02002530static int ath10k_mac_vif_recalc_txbf(struct ath10k *ar,
2531 struct ieee80211_vif *vif,
2532 struct ieee80211_sta_vht_cap vht_cap)
2533{
2534 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
2535 int ret;
2536 u32 param;
2537 u32 value;
2538
Vivek Natarajan08e75ea2015-08-04 10:45:11 +05302539 if (ath10k_wmi_get_txbf_conf_scheme(ar) != WMI_TXBF_CONF_AFTER_ASSOC)
2540 return 0;
2541
Michal Kazior139e1702015-02-15 16:50:42 +02002542 if (!(ar->vht_cap_info &
2543 (IEEE80211_VHT_CAP_SU_BEAMFORMEE_CAPABLE |
2544 IEEE80211_VHT_CAP_MU_BEAMFORMEE_CAPABLE |
2545 IEEE80211_VHT_CAP_SU_BEAMFORMER_CAPABLE |
2546 IEEE80211_VHT_CAP_MU_BEAMFORMER_CAPABLE)))
2547 return 0;
2548
2549 param = ar->wmi.vdev_param->txbf;
2550 value = 0;
2551
2552 if (WARN_ON(param == WMI_VDEV_PARAM_UNSUPPORTED))
2553 return 0;
2554
2555 /* The following logic is correct. If a remote STA advertises support
2556 * for being a beamformer then we should enable us being a beamformee.
2557 */
2558
2559 if (ar->vht_cap_info &
2560 (IEEE80211_VHT_CAP_SU_BEAMFORMEE_CAPABLE |
2561 IEEE80211_VHT_CAP_MU_BEAMFORMEE_CAPABLE)) {
2562 if (vht_cap.cap & IEEE80211_VHT_CAP_SU_BEAMFORMER_CAPABLE)
2563 value |= WMI_VDEV_PARAM_TXBF_SU_TX_BFEE;
2564
2565 if (vht_cap.cap & IEEE80211_VHT_CAP_MU_BEAMFORMER_CAPABLE)
2566 value |= WMI_VDEV_PARAM_TXBF_MU_TX_BFEE;
2567 }
2568
2569 if (ar->vht_cap_info &
2570 (IEEE80211_VHT_CAP_SU_BEAMFORMER_CAPABLE |
2571 IEEE80211_VHT_CAP_MU_BEAMFORMER_CAPABLE)) {
2572 if (vht_cap.cap & IEEE80211_VHT_CAP_SU_BEAMFORMEE_CAPABLE)
2573 value |= WMI_VDEV_PARAM_TXBF_SU_TX_BFER;
2574
2575 if (vht_cap.cap & IEEE80211_VHT_CAP_MU_BEAMFORMEE_CAPABLE)
2576 value |= WMI_VDEV_PARAM_TXBF_MU_TX_BFER;
2577 }
2578
2579 if (value & WMI_VDEV_PARAM_TXBF_MU_TX_BFEE)
2580 value |= WMI_VDEV_PARAM_TXBF_SU_TX_BFEE;
2581
2582 if (value & WMI_VDEV_PARAM_TXBF_MU_TX_BFER)
2583 value |= WMI_VDEV_PARAM_TXBF_SU_TX_BFER;
2584
2585 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, param, value);
2586 if (ret) {
2587 ath10k_warn(ar, "failed to submit vdev param txbf 0x%x: %d\n",
2588 value, ret);
2589 return ret;
2590 }
2591
2592 return 0;
2593}
2594
Kalle Valo5e3dd152013-06-12 20:52:10 +03002595/* can be called only in mac80211 callbacks due to `key_count` usage */
2596static void ath10k_bss_assoc(struct ieee80211_hw *hw,
2597 struct ieee80211_vif *vif,
2598 struct ieee80211_bss_conf *bss_conf)
2599{
2600 struct ath10k *ar = hw->priv;
2601 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kazior90046f52014-02-14 14:45:51 +01002602 struct ieee80211_sta_ht_cap ht_cap;
Michal Kazior139e1702015-02-15 16:50:42 +02002603 struct ieee80211_sta_vht_cap vht_cap;
Kalle Valob9ada652013-10-16 15:44:46 +03002604 struct wmi_peer_assoc_complete_arg peer_arg;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002605 struct ieee80211_sta *ap_sta;
2606 int ret;
2607
Michal Kazior548db542013-07-05 16:15:15 +03002608 lockdep_assert_held(&ar->conf_mutex);
2609
Michal Kazior077efc82014-10-21 10:10:29 +03002610 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %i assoc bssid %pM aid %d\n",
2611 arvif->vdev_id, arvif->bssid, arvif->aid);
2612
Kalle Valo5e3dd152013-06-12 20:52:10 +03002613 rcu_read_lock();
2614
2615 ap_sta = ieee80211_find_sta(vif, bss_conf->bssid);
2616 if (!ap_sta) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002617 ath10k_warn(ar, "failed to find station entry for bss %pM vdev %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02002618 bss_conf->bssid, arvif->vdev_id);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002619 rcu_read_unlock();
2620 return;
2621 }
2622
Michal Kazior90046f52014-02-14 14:45:51 +01002623 /* ap_sta must be accessed only within rcu section which must be left
2624 * before calling ath10k_setup_peer_smps() which might sleep. */
2625 ht_cap = ap_sta->ht_cap;
Michal Kazior139e1702015-02-15 16:50:42 +02002626 vht_cap = ap_sta->vht_cap;
Michal Kazior90046f52014-02-14 14:45:51 +01002627
Michal Kazior590922a2014-10-21 10:10:29 +03002628 ret = ath10k_peer_assoc_prepare(ar, vif, ap_sta, &peer_arg);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002629 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002630 ath10k_warn(ar, "failed to prepare peer assoc for %pM vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02002631 bss_conf->bssid, arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002632 rcu_read_unlock();
2633 return;
2634 }
2635
2636 rcu_read_unlock();
2637
Kalle Valob9ada652013-10-16 15:44:46 +03002638 ret = ath10k_wmi_peer_assoc(ar, &peer_arg);
2639 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002640 ath10k_warn(ar, "failed to run peer assoc for %pM vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02002641 bss_conf->bssid, arvif->vdev_id, ret);
Kalle Valob9ada652013-10-16 15:44:46 +03002642 return;
2643 }
2644
Michal Kazior90046f52014-02-14 14:45:51 +01002645 ret = ath10k_setup_peer_smps(ar, arvif, bss_conf->bssid, &ht_cap);
2646 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002647 ath10k_warn(ar, "failed to setup peer SMPS for vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02002648 arvif->vdev_id, ret);
Michal Kazior90046f52014-02-14 14:45:51 +01002649 return;
2650 }
2651
Michal Kazior139e1702015-02-15 16:50:42 +02002652 ret = ath10k_mac_vif_recalc_txbf(ar, vif, vht_cap);
2653 if (ret) {
2654 ath10k_warn(ar, "failed to recalc txbf for vdev %i on bss %pM: %d\n",
2655 arvif->vdev_id, bss_conf->bssid, ret);
2656 return;
2657 }
2658
Michal Kazior7aa7a722014-08-25 12:09:38 +02002659 ath10k_dbg(ar, ATH10K_DBG_MAC,
Kalle Valo60c3daa2013-09-08 17:56:07 +03002660 "mac vdev %d up (associated) bssid %pM aid %d\n",
2661 arvif->vdev_id, bss_conf->bssid, bss_conf->aid);
2662
Michal Kazior077efc82014-10-21 10:10:29 +03002663 WARN_ON(arvif->is_up);
2664
Michal Kaziorc930f742014-01-23 11:38:25 +01002665 arvif->aid = bss_conf->aid;
Kalle Valob25f32c2014-09-14 12:50:49 +03002666 ether_addr_copy(arvif->bssid, bss_conf->bssid);
Michal Kaziorc930f742014-01-23 11:38:25 +01002667
2668 ret = ath10k_wmi_vdev_up(ar, arvif->vdev_id, arvif->aid, arvif->bssid);
2669 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002670 ath10k_warn(ar, "failed to set vdev %d up: %d\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03002671 arvif->vdev_id, ret);
Michal Kaziorc930f742014-01-23 11:38:25 +01002672 return;
2673 }
2674
2675 arvif->is_up = true;
Michal Kazior0a987fb2015-02-13 13:30:15 +01002676
2677 /* Workaround: Some firmware revisions (tested with qca6174
2678 * WLAN.RM.2.0-00073) have buggy powersave state machine and must be
2679 * poked with peer param command.
2680 */
2681 ret = ath10k_wmi_peer_set_param(ar, arvif->vdev_id, arvif->bssid,
2682 WMI_PEER_DUMMY_VAR, 1);
2683 if (ret) {
2684 ath10k_warn(ar, "failed to poke peer %pM param for ps workaround on vdev %i: %d\n",
2685 arvif->bssid, arvif->vdev_id, ret);
2686 return;
2687 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002688}
2689
Kalle Valo5e3dd152013-06-12 20:52:10 +03002690static void ath10k_bss_disassoc(struct ieee80211_hw *hw,
2691 struct ieee80211_vif *vif)
2692{
2693 struct ath10k *ar = hw->priv;
2694 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kazior139e1702015-02-15 16:50:42 +02002695 struct ieee80211_sta_vht_cap vht_cap = {};
Kalle Valo5e3dd152013-06-12 20:52:10 +03002696 int ret;
2697
Michal Kazior548db542013-07-05 16:15:15 +03002698 lockdep_assert_held(&ar->conf_mutex);
2699
Michal Kazior077efc82014-10-21 10:10:29 +03002700 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %i disassoc bssid %pM\n",
2701 arvif->vdev_id, arvif->bssid);
Kalle Valo60c3daa2013-09-08 17:56:07 +03002702
Kalle Valo5e3dd152013-06-12 20:52:10 +03002703 ret = ath10k_wmi_vdev_down(ar, arvif->vdev_id);
Michal Kazior077efc82014-10-21 10:10:29 +03002704 if (ret)
2705 ath10k_warn(ar, "faield to down vdev %i: %d\n",
2706 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002707
SenthilKumar Jegadeesan627613f2015-01-29 13:50:38 +02002708 arvif->def_wep_key_idx = -1;
2709
Michal Kazior139e1702015-02-15 16:50:42 +02002710 ret = ath10k_mac_vif_recalc_txbf(ar, vif, vht_cap);
2711 if (ret) {
2712 ath10k_warn(ar, "failed to recalc txbf for vdev %i: %d\n",
2713 arvif->vdev_id, ret);
2714 return;
2715 }
2716
Michal Kaziorc930f742014-01-23 11:38:25 +01002717 arvif->is_up = false;
Michal Kaziorcc9904e2015-03-10 16:22:01 +02002718
2719 cancel_delayed_work_sync(&arvif->connection_loss_work);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002720}
2721
Michal Kazior590922a2014-10-21 10:10:29 +03002722static int ath10k_station_assoc(struct ath10k *ar,
2723 struct ieee80211_vif *vif,
2724 struct ieee80211_sta *sta,
2725 bool reassoc)
Kalle Valo5e3dd152013-06-12 20:52:10 +03002726{
Michal Kazior590922a2014-10-21 10:10:29 +03002727 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Kalle Valob9ada652013-10-16 15:44:46 +03002728 struct wmi_peer_assoc_complete_arg peer_arg;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002729 int ret = 0;
2730
Michal Kazior548db542013-07-05 16:15:15 +03002731 lockdep_assert_held(&ar->conf_mutex);
2732
Michal Kazior590922a2014-10-21 10:10:29 +03002733 ret = ath10k_peer_assoc_prepare(ar, vif, sta, &peer_arg);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002734 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002735 ath10k_warn(ar, "failed to prepare WMI peer assoc for %pM vdev %i: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02002736 sta->addr, arvif->vdev_id, ret);
Kalle Valob9ada652013-10-16 15:44:46 +03002737 return ret;
2738 }
2739
2740 ret = ath10k_wmi_peer_assoc(ar, &peer_arg);
2741 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002742 ath10k_warn(ar, "failed to run peer assoc for STA %pM vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02002743 sta->addr, arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002744 return ret;
2745 }
2746
Michal Kaziorb1ecde32014-10-21 10:10:29 +03002747 /* Re-assoc is run only to update supported rates for given station. It
2748 * doesn't make much sense to reconfigure the peer completely.
2749 */
2750 if (!reassoc) {
2751 ret = ath10k_setup_peer_smps(ar, arvif, sta->addr,
2752 &sta->ht_cap);
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02002753 if (ret) {
Michal Kaziorb1ecde32014-10-21 10:10:29 +03002754 ath10k_warn(ar, "failed to setup peer SMPS for vdev %d: %d\n",
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02002755 arvif->vdev_id, ret);
2756 return ret;
2757 }
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02002758
Michal Kaziorb1ecde32014-10-21 10:10:29 +03002759 ret = ath10k_peer_assoc_qos_ap(ar, arvif, sta);
2760 if (ret) {
2761 ath10k_warn(ar, "failed to set qos params for STA %pM for vdev %i: %d\n",
2762 sta->addr, arvif->vdev_id, ret);
2763 return ret;
2764 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002765
Michal Kaziorb1ecde32014-10-21 10:10:29 +03002766 if (!sta->wme) {
2767 arvif->num_legacy_stations++;
2768 ret = ath10k_recalc_rtscts_prot(arvif);
2769 if (ret) {
2770 ath10k_warn(ar, "failed to recalculate rts/cts prot for vdev %d: %d\n",
2771 arvif->vdev_id, ret);
2772 return ret;
2773 }
2774 }
2775
SenthilKumar Jegadeesan627613f2015-01-29 13:50:38 +02002776 /* Plumb cached keys only for static WEP */
2777 if (arvif->def_wep_key_idx != -1) {
2778 ret = ath10k_install_peer_wep_keys(arvif, sta->addr);
2779 if (ret) {
2780 ath10k_warn(ar, "failed to install peer wep keys for vdev %i: %d\n",
2781 arvif->vdev_id, ret);
2782 return ret;
2783 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03002784 }
2785 }
2786
Kalle Valo5e3dd152013-06-12 20:52:10 +03002787 return ret;
2788}
2789
Michal Kazior590922a2014-10-21 10:10:29 +03002790static int ath10k_station_disassoc(struct ath10k *ar,
2791 struct ieee80211_vif *vif,
Kalle Valo5e3dd152013-06-12 20:52:10 +03002792 struct ieee80211_sta *sta)
2793{
Michal Kazior590922a2014-10-21 10:10:29 +03002794 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002795 int ret = 0;
2796
2797 lockdep_assert_held(&ar->conf_mutex);
2798
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02002799 if (!sta->wme) {
2800 arvif->num_legacy_stations--;
2801 ret = ath10k_recalc_rtscts_prot(arvif);
2802 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002803 ath10k_warn(ar, "failed to recalculate rts/cts prot for vdev %d: %d\n",
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02002804 arvif->vdev_id, ret);
2805 return ret;
2806 }
2807 }
2808
Kalle Valo5e3dd152013-06-12 20:52:10 +03002809 ret = ath10k_clear_peer_keys(arvif, sta->addr);
2810 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002811 ath10k_warn(ar, "failed to clear all peer wep keys for vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02002812 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002813 return ret;
2814 }
2815
2816 return ret;
2817}
2818
2819/**************/
2820/* Regulatory */
2821/**************/
2822
2823static int ath10k_update_channel_list(struct ath10k *ar)
2824{
2825 struct ieee80211_hw *hw = ar->hw;
2826 struct ieee80211_supported_band **bands;
2827 enum ieee80211_band band;
2828 struct ieee80211_channel *channel;
2829 struct wmi_scan_chan_list_arg arg = {0};
2830 struct wmi_channel_arg *ch;
2831 bool passive;
2832 int len;
2833 int ret;
2834 int i;
2835
Michal Kazior548db542013-07-05 16:15:15 +03002836 lockdep_assert_held(&ar->conf_mutex);
2837
Kalle Valo5e3dd152013-06-12 20:52:10 +03002838 bands = hw->wiphy->bands;
2839 for (band = 0; band < IEEE80211_NUM_BANDS; band++) {
2840 if (!bands[band])
2841 continue;
2842
2843 for (i = 0; i < bands[band]->n_channels; i++) {
2844 if (bands[band]->channels[i].flags &
2845 IEEE80211_CHAN_DISABLED)
2846 continue;
2847
2848 arg.n_channels++;
2849 }
2850 }
2851
2852 len = sizeof(struct wmi_channel_arg) * arg.n_channels;
2853 arg.channels = kzalloc(len, GFP_KERNEL);
2854 if (!arg.channels)
2855 return -ENOMEM;
2856
2857 ch = arg.channels;
2858 for (band = 0; band < IEEE80211_NUM_BANDS; band++) {
2859 if (!bands[band])
2860 continue;
2861
2862 for (i = 0; i < bands[band]->n_channels; i++) {
2863 channel = &bands[band]->channels[i];
2864
2865 if (channel->flags & IEEE80211_CHAN_DISABLED)
2866 continue;
2867
2868 ch->allow_ht = true;
2869
2870 /* FIXME: when should we really allow VHT? */
2871 ch->allow_vht = true;
2872
2873 ch->allow_ibss =
Luis R. Rodriguez8fe02e12013-10-21 19:22:25 +02002874 !(channel->flags & IEEE80211_CHAN_NO_IR);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002875
2876 ch->ht40plus =
2877 !(channel->flags & IEEE80211_CHAN_NO_HT40PLUS);
2878
Marek Puzyniake8a50f82013-11-20 09:59:47 +02002879 ch->chan_radar =
2880 !!(channel->flags & IEEE80211_CHAN_RADAR);
2881
Luis R. Rodriguez8fe02e12013-10-21 19:22:25 +02002882 passive = channel->flags & IEEE80211_CHAN_NO_IR;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002883 ch->passive = passive;
2884
2885 ch->freq = channel->center_freq;
Michal Kazior2d667212014-09-18 15:21:21 +02002886 ch->band_center_freq1 = channel->center_freq;
Michal Kazior89c5c842013-10-23 04:02:13 -07002887 ch->min_power = 0;
Michal Kazior02256932013-10-23 04:02:14 -07002888 ch->max_power = channel->max_power * 2;
2889 ch->max_reg_power = channel->max_reg_power * 2;
2890 ch->max_antenna_gain = channel->max_antenna_gain * 2;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002891 ch->reg_class_id = 0; /* FIXME */
2892
2893 /* FIXME: why use only legacy modes, why not any
2894 * HT/VHT modes? Would that even make any
2895 * difference? */
2896 if (channel->band == IEEE80211_BAND_2GHZ)
2897 ch->mode = MODE_11G;
2898 else
2899 ch->mode = MODE_11A;
2900
2901 if (WARN_ON_ONCE(ch->mode == MODE_UNKNOWN))
2902 continue;
2903
Michal Kazior7aa7a722014-08-25 12:09:38 +02002904 ath10k_dbg(ar, ATH10K_DBG_WMI,
Kalle Valo60c3daa2013-09-08 17:56:07 +03002905 "mac channel [%zd/%d] freq %d maxpower %d regpower %d antenna %d mode %d\n",
2906 ch - arg.channels, arg.n_channels,
Kalle Valo5e3dd152013-06-12 20:52:10 +03002907 ch->freq, ch->max_power, ch->max_reg_power,
2908 ch->max_antenna_gain, ch->mode);
2909
2910 ch++;
2911 }
2912 }
2913
2914 ret = ath10k_wmi_scan_chan_list(ar, &arg);
2915 kfree(arg.channels);
2916
2917 return ret;
2918}
2919
Marek Puzyniak821af6a2014-03-21 17:46:57 +02002920static enum wmi_dfs_region
2921ath10k_mac_get_dfs_region(enum nl80211_dfs_regions dfs_region)
2922{
2923 switch (dfs_region) {
2924 case NL80211_DFS_UNSET:
2925 return WMI_UNINIT_DFS_DOMAIN;
2926 case NL80211_DFS_FCC:
2927 return WMI_FCC_DFS_DOMAIN;
2928 case NL80211_DFS_ETSI:
2929 return WMI_ETSI_DFS_DOMAIN;
2930 case NL80211_DFS_JP:
2931 return WMI_MKK4_DFS_DOMAIN;
2932 }
2933 return WMI_UNINIT_DFS_DOMAIN;
2934}
2935
Michal Kaziorf7843d72013-07-16 09:38:52 +02002936static void ath10k_regd_update(struct ath10k *ar)
Kalle Valo5e3dd152013-06-12 20:52:10 +03002937{
Kalle Valo5e3dd152013-06-12 20:52:10 +03002938 struct reg_dmn_pair_mapping *regpair;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002939 int ret;
Marek Puzyniak821af6a2014-03-21 17:46:57 +02002940 enum wmi_dfs_region wmi_dfs_reg;
2941 enum nl80211_dfs_regions nl_dfs_reg;
Kalle Valo5e3dd152013-06-12 20:52:10 +03002942
Michal Kaziorf7843d72013-07-16 09:38:52 +02002943 lockdep_assert_held(&ar->conf_mutex);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002944
2945 ret = ath10k_update_channel_list(ar);
2946 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02002947 ath10k_warn(ar, "failed to update channel list: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002948
2949 regpair = ar->ath_common.regulatory.regpair;
Michal Kaziorf7843d72013-07-16 09:38:52 +02002950
Marek Puzyniak821af6a2014-03-21 17:46:57 +02002951 if (config_enabled(CONFIG_ATH10K_DFS_CERTIFIED) && ar->dfs_detector) {
2952 nl_dfs_reg = ar->dfs_detector->region;
2953 wmi_dfs_reg = ath10k_mac_get_dfs_region(nl_dfs_reg);
2954 } else {
2955 wmi_dfs_reg = WMI_UNINIT_DFS_DOMAIN;
2956 }
2957
Kalle Valo5e3dd152013-06-12 20:52:10 +03002958 /* Target allows setting up per-band regdomain but ath_common provides
2959 * a combined one only */
2960 ret = ath10k_wmi_pdev_set_regdomain(ar,
Kalle Valoef8c0012014-02-13 18:13:12 +02002961 regpair->reg_domain,
2962 regpair->reg_domain, /* 2ghz */
2963 regpair->reg_domain, /* 5ghz */
Kalle Valo5e3dd152013-06-12 20:52:10 +03002964 regpair->reg_2ghz_ctl,
Marek Puzyniak821af6a2014-03-21 17:46:57 +02002965 regpair->reg_5ghz_ctl,
2966 wmi_dfs_reg);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002967 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02002968 ath10k_warn(ar, "failed to set pdev regdomain: %d\n", ret);
Michal Kaziorf7843d72013-07-16 09:38:52 +02002969}
Michal Kazior548db542013-07-05 16:15:15 +03002970
Michal Kaziorf7843d72013-07-16 09:38:52 +02002971static void ath10k_reg_notifier(struct wiphy *wiphy,
2972 struct regulatory_request *request)
2973{
2974 struct ieee80211_hw *hw = wiphy_to_ieee80211_hw(wiphy);
2975 struct ath10k *ar = hw->priv;
Janusz Dziedzic9702c682013-11-20 09:59:41 +02002976 bool result;
Michal Kaziorf7843d72013-07-16 09:38:52 +02002977
2978 ath_reg_notifier_apply(wiphy, request, &ar->ath_common.regulatory);
2979
Janusz Dziedzic9702c682013-11-20 09:59:41 +02002980 if (config_enabled(CONFIG_ATH10K_DFS_CERTIFIED) && ar->dfs_detector) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02002981 ath10k_dbg(ar, ATH10K_DBG_REGULATORY, "dfs region 0x%x\n",
Janusz Dziedzic9702c682013-11-20 09:59:41 +02002982 request->dfs_region);
2983 result = ar->dfs_detector->set_dfs_domain(ar->dfs_detector,
2984 request->dfs_region);
2985 if (!result)
Michal Kazior7aa7a722014-08-25 12:09:38 +02002986 ath10k_warn(ar, "DFS region 0x%X not supported, will trigger radar for every pulse\n",
Janusz Dziedzic9702c682013-11-20 09:59:41 +02002987 request->dfs_region);
2988 }
2989
Michal Kaziorf7843d72013-07-16 09:38:52 +02002990 mutex_lock(&ar->conf_mutex);
2991 if (ar->state == ATH10K_STATE_ON)
2992 ath10k_regd_update(ar);
Michal Kazior548db542013-07-05 16:15:15 +03002993 mutex_unlock(&ar->conf_mutex);
Kalle Valo5e3dd152013-06-12 20:52:10 +03002994}
2995
2996/***************/
2997/* TX handlers */
2998/***************/
2999
Michal Kazior96d828d2015-03-31 10:26:23 +00003000void ath10k_mac_tx_lock(struct ath10k *ar, int reason)
3001{
3002 lockdep_assert_held(&ar->htt.tx_lock);
3003
3004 WARN_ON(reason >= ATH10K_TX_PAUSE_MAX);
3005 ar->tx_paused |= BIT(reason);
3006 ieee80211_stop_queues(ar->hw);
3007}
3008
3009static void ath10k_mac_tx_unlock_iter(void *data, u8 *mac,
3010 struct ieee80211_vif *vif)
3011{
3012 struct ath10k *ar = data;
3013 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
3014
3015 if (arvif->tx_paused)
3016 return;
3017
3018 ieee80211_wake_queue(ar->hw, arvif->vdev_id);
3019}
3020
3021void ath10k_mac_tx_unlock(struct ath10k *ar, int reason)
3022{
3023 lockdep_assert_held(&ar->htt.tx_lock);
3024
3025 WARN_ON(reason >= ATH10K_TX_PAUSE_MAX);
3026 ar->tx_paused &= ~BIT(reason);
3027
3028 if (ar->tx_paused)
3029 return;
3030
3031 ieee80211_iterate_active_interfaces_atomic(ar->hw,
3032 IEEE80211_IFACE_ITER_RESUME_ALL,
3033 ath10k_mac_tx_unlock_iter,
3034 ar);
Michal Kazior3a73d1a2015-08-06 14:46:54 +02003035
3036 ieee80211_wake_queue(ar->hw, ar->hw->offchannel_tx_hw_queue);
Michal Kazior96d828d2015-03-31 10:26:23 +00003037}
3038
3039void ath10k_mac_vif_tx_lock(struct ath10k_vif *arvif, int reason)
3040{
3041 struct ath10k *ar = arvif->ar;
3042
3043 lockdep_assert_held(&ar->htt.tx_lock);
3044
3045 WARN_ON(reason >= BITS_PER_LONG);
3046 arvif->tx_paused |= BIT(reason);
3047 ieee80211_stop_queue(ar->hw, arvif->vdev_id);
3048}
3049
3050void ath10k_mac_vif_tx_unlock(struct ath10k_vif *arvif, int reason)
3051{
3052 struct ath10k *ar = arvif->ar;
3053
3054 lockdep_assert_held(&ar->htt.tx_lock);
3055
3056 WARN_ON(reason >= BITS_PER_LONG);
3057 arvif->tx_paused &= ~BIT(reason);
3058
3059 if (ar->tx_paused)
3060 return;
3061
3062 if (arvif->tx_paused)
3063 return;
3064
3065 ieee80211_wake_queue(ar->hw, arvif->vdev_id);
3066}
3067
Michal Kaziorb4aa5392015-03-31 10:26:24 +00003068static void ath10k_mac_vif_handle_tx_pause(struct ath10k_vif *arvif,
3069 enum wmi_tlv_tx_pause_id pause_id,
3070 enum wmi_tlv_tx_pause_action action)
3071{
3072 struct ath10k *ar = arvif->ar;
3073
3074 lockdep_assert_held(&ar->htt.tx_lock);
3075
Michal Kazioracd0b272015-07-09 13:08:38 +02003076 switch (action) {
3077 case WMI_TLV_TX_PAUSE_ACTION_STOP:
3078 ath10k_mac_vif_tx_lock(arvif, pause_id);
Michal Kaziorb4aa5392015-03-31 10:26:24 +00003079 break;
Michal Kazioracd0b272015-07-09 13:08:38 +02003080 case WMI_TLV_TX_PAUSE_ACTION_WAKE:
3081 ath10k_mac_vif_tx_unlock(arvif, pause_id);
3082 break;
Michal Kaziorb4aa5392015-03-31 10:26:24 +00003083 default:
Michal Kazioracd0b272015-07-09 13:08:38 +02003084 ath10k_warn(ar, "received unknown tx pause action %d on vdev %i, ignoring\n",
3085 action, arvif->vdev_id);
Michal Kaziorb4aa5392015-03-31 10:26:24 +00003086 break;
3087 }
3088}
3089
3090struct ath10k_mac_tx_pause {
3091 u32 vdev_id;
3092 enum wmi_tlv_tx_pause_id pause_id;
3093 enum wmi_tlv_tx_pause_action action;
3094};
3095
3096static void ath10k_mac_handle_tx_pause_iter(void *data, u8 *mac,
3097 struct ieee80211_vif *vif)
3098{
3099 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
3100 struct ath10k_mac_tx_pause *arg = data;
3101
Michal Kazioracd0b272015-07-09 13:08:38 +02003102 if (arvif->vdev_id != arg->vdev_id)
3103 return;
3104
Michal Kaziorb4aa5392015-03-31 10:26:24 +00003105 ath10k_mac_vif_handle_tx_pause(arvif, arg->pause_id, arg->action);
3106}
3107
Michal Kazioracd0b272015-07-09 13:08:38 +02003108void ath10k_mac_handle_tx_pause_vdev(struct ath10k *ar, u32 vdev_id,
3109 enum wmi_tlv_tx_pause_id pause_id,
3110 enum wmi_tlv_tx_pause_action action)
Michal Kaziorb4aa5392015-03-31 10:26:24 +00003111{
3112 struct ath10k_mac_tx_pause arg = {
3113 .vdev_id = vdev_id,
3114 .pause_id = pause_id,
3115 .action = action,
3116 };
3117
3118 spin_lock_bh(&ar->htt.tx_lock);
3119 ieee80211_iterate_active_interfaces_atomic(ar->hw,
3120 IEEE80211_IFACE_ITER_RESUME_ALL,
3121 ath10k_mac_handle_tx_pause_iter,
3122 &arg);
3123 spin_unlock_bh(&ar->htt.tx_lock);
3124}
3125
Michal Kaziord740d8f2015-03-30 09:51:51 +03003126static enum ath10k_hw_txrx_mode
Michal Kazior6a2636d2015-11-18 06:59:16 +01003127ath10k_mac_tx_h_get_txmode(struct ath10k *ar,
3128 struct ieee80211_vif *vif,
3129 struct ieee80211_sta *sta,
3130 struct sk_buff *skb)
Michal Kaziord740d8f2015-03-30 09:51:51 +03003131{
3132 const struct ieee80211_hdr *hdr = (void *)skb->data;
3133 __le16 fc = hdr->frame_control;
3134
3135 if (!vif || vif->type == NL80211_IFTYPE_MONITOR)
3136 return ATH10K_HW_TXRX_RAW;
3137
3138 if (ieee80211_is_mgmt(fc))
3139 return ATH10K_HW_TXRX_MGMT;
3140
3141 /* Workaround:
3142 *
3143 * NullFunc frames are mostly used to ping if a client or AP are still
3144 * reachable and responsive. This implies tx status reports must be
3145 * accurate - otherwise either mac80211 or userspace (e.g. hostapd) can
3146 * come to a conclusion that the other end disappeared and tear down
3147 * BSS connection or it can never disconnect from BSS/client (which is
3148 * the case).
3149 *
3150 * Firmware with HTT older than 3.0 delivers incorrect tx status for
3151 * NullFunc frames to driver. However there's a HTT Mgmt Tx command
3152 * which seems to deliver correct tx reports for NullFunc frames. The
3153 * downside of using it is it ignores client powersave state so it can
3154 * end up disconnecting sleeping clients in AP mode. It should fix STA
3155 * mode though because AP don't sleep.
3156 */
3157 if (ar->htt.target_version_major < 3 &&
3158 (ieee80211_is_nullfunc(fc) || ieee80211_is_qos_nullfunc(fc)) &&
3159 !test_bit(ATH10K_FW_FEATURE_HAS_WMI_MGMT_TX, ar->fw_features))
3160 return ATH10K_HW_TXRX_MGMT;
3161
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03003162 /* Workaround:
3163 *
3164 * Some wmi-tlv firmwares for qca6174 have broken Tx key selection for
3165 * NativeWifi txmode - it selects AP key instead of peer key. It seems
3166 * to work with Ethernet txmode so use it.
David Liuccec9032015-07-24 20:25:32 +03003167 *
3168 * FIXME: Check if raw mode works with TDLS.
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03003169 */
3170 if (ieee80211_is_data_present(fc) && sta && sta->tdls)
3171 return ATH10K_HW_TXRX_ETHERNET;
3172
David Liuccec9032015-07-24 20:25:32 +03003173 if (test_bit(ATH10K_FLAG_RAW_MODE, &ar->dev_flags))
3174 return ATH10K_HW_TXRX_RAW;
3175
Michal Kaziord740d8f2015-03-30 09:51:51 +03003176 return ATH10K_HW_TXRX_NATIVE_WIFI;
3177}
3178
David Liuccec9032015-07-24 20:25:32 +03003179static bool ath10k_tx_h_use_hwcrypto(struct ieee80211_vif *vif,
Michal Kaziorfd12cb32015-11-18 06:59:15 +01003180 struct sk_buff *skb)
3181{
3182 const struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
3183 const struct ieee80211_hdr *hdr = (void *)skb->data;
David Liuccec9032015-07-24 20:25:32 +03003184 const u32 mask = IEEE80211_TX_INTFL_DONT_ENCRYPT |
3185 IEEE80211_TX_CTL_INJECTED;
Michal Kaziorfd12cb32015-11-18 06:59:15 +01003186
3187 if (!ieee80211_has_protected(hdr->frame_control))
3188 return false;
3189
David Liuccec9032015-07-24 20:25:32 +03003190 if ((info->flags & mask) == mask)
3191 return false;
Michal Kaziorfd12cb32015-11-18 06:59:15 +01003192
David Liuccec9032015-07-24 20:25:32 +03003193 if (vif)
3194 return !ath10k_vif_to_arvif(vif)->nohwcrypt;
Michal Kaziorfd12cb32015-11-18 06:59:15 +01003195
David Liuccec9032015-07-24 20:25:32 +03003196 return true;
3197}
3198
Michal Kazior4b604552014-07-21 21:03:09 +03003199/* HTT Tx uses Native Wifi tx mode which expects 802.11 frames without QoS
3200 * Control in the header.
Kalle Valo5e3dd152013-06-12 20:52:10 +03003201 */
Michal Kazior4b604552014-07-21 21:03:09 +03003202static void ath10k_tx_h_nwifi(struct ieee80211_hw *hw, struct sk_buff *skb)
Kalle Valo5e3dd152013-06-12 20:52:10 +03003203{
3204 struct ieee80211_hdr *hdr = (void *)skb->data;
Michal Kaziorc21c64d2014-07-21 21:03:10 +03003205 struct ath10k_skb_cb *cb = ATH10K_SKB_CB(skb);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003206 u8 *qos_ctl;
3207
3208 if (!ieee80211_is_data_qos(hdr->frame_control))
3209 return;
3210
3211 qos_ctl = ieee80211_get_qos_ctl(hdr);
Michal Kaziorba0ccd72013-07-22 14:25:28 +02003212 memmove(skb->data + IEEE80211_QOS_CTL_LEN,
3213 skb->data, (void *)qos_ctl - (void *)skb->data);
3214 skb_pull(skb, IEEE80211_QOS_CTL_LEN);
Michal Kaziorc21c64d2014-07-21 21:03:10 +03003215
Michal Kazior8bad8dc2015-03-11 14:25:26 +01003216 /* Some firmware revisions don't handle sending QoS NullFunc well.
3217 * These frames are mainly used for CQM purposes so it doesn't really
3218 * matter whether QoS NullFunc or NullFunc are sent.
Michal Kaziorc21c64d2014-07-21 21:03:10 +03003219 */
Michal Kaziorbf0a26d2015-01-24 12:14:51 +02003220 hdr = (void *)skb->data;
Michal Kazior8bad8dc2015-03-11 14:25:26 +01003221 if (ieee80211_is_qos_nullfunc(hdr->frame_control))
Michal Kazior609db222015-11-18 06:59:22 +01003222 cb->flags &= ~ATH10K_SKB_F_QOS;
Michal Kazior8bad8dc2015-03-11 14:25:26 +01003223
3224 hdr->frame_control &= ~__cpu_to_le16(IEEE80211_STYPE_QOS_DATA);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003225}
3226
Michal Kaziord740d8f2015-03-30 09:51:51 +03003227static void ath10k_tx_h_8023(struct sk_buff *skb)
3228{
3229 struct ieee80211_hdr *hdr;
3230 struct rfc1042_hdr *rfc1042;
3231 struct ethhdr *eth;
3232 size_t hdrlen;
3233 u8 da[ETH_ALEN];
3234 u8 sa[ETH_ALEN];
3235 __be16 type;
3236
3237 hdr = (void *)skb->data;
3238 hdrlen = ieee80211_hdrlen(hdr->frame_control);
3239 rfc1042 = (void *)skb->data + hdrlen;
3240
3241 ether_addr_copy(da, ieee80211_get_DA(hdr));
3242 ether_addr_copy(sa, ieee80211_get_SA(hdr));
3243 type = rfc1042->snap_type;
3244
3245 skb_pull(skb, hdrlen + sizeof(*rfc1042));
3246 skb_push(skb, sizeof(*eth));
3247
3248 eth = (void *)skb->data;
3249 ether_addr_copy(eth->h_dest, da);
3250 ether_addr_copy(eth->h_source, sa);
3251 eth->h_proto = type;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003252}
3253
Michal Kazior4b604552014-07-21 21:03:09 +03003254static void ath10k_tx_h_add_p2p_noa_ie(struct ath10k *ar,
3255 struct ieee80211_vif *vif,
3256 struct sk_buff *skb)
Kalle Valo5e3dd152013-06-12 20:52:10 +03003257{
3258 struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003259 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
3260
3261 /* This is case only for P2P_GO */
3262 if (arvif->vdev_type != WMI_VDEV_TYPE_AP ||
3263 arvif->vdev_subtype != WMI_VDEV_SUBTYPE_P2P_GO)
3264 return;
3265
3266 if (unlikely(ieee80211_is_probe_resp(hdr->frame_control))) {
3267 spin_lock_bh(&ar->data_lock);
3268 if (arvif->u.ap.noa_data)
3269 if (!pskb_expand_head(skb, 0, arvif->u.ap.noa_len,
3270 GFP_ATOMIC))
3271 memcpy(skb_put(skb, arvif->u.ap.noa_len),
3272 arvif->u.ap.noa_data,
3273 arvif->u.ap.noa_len);
3274 spin_unlock_bh(&ar->data_lock);
3275 }
3276}
3277
Vasanthakumar Thiagarajand39de992015-11-05 11:34:00 +05303278bool ath10k_mac_tx_frm_has_freq(struct ath10k *ar)
Michal Kazior8d6d3622014-11-24 14:58:31 +01003279{
3280 /* FIXME: Not really sure since when the behaviour changed. At some
3281 * point new firmware stopped requiring creation of peer entries for
3282 * offchannel tx (and actually creating them causes issues with wmi-htc
3283 * tx credit replenishment and reliability). Assuming it's at least 3.4
3284 * because that's when the `freq` was introduced to TX_FRM HTT command.
3285 */
Vasanthakumar Thiagarajan8921f5f2015-11-05 11:33:59 +05303286 return (ar->htt.target_version_major >= 3 &&
Vasanthakumar Thiagarajand39de992015-11-05 11:34:00 +05303287 ar->htt.target_version_minor >= 4 &&
3288 ar->htt.op_version == ATH10K_FW_HTT_OP_VERSION_TLV);
Michal Kazior8d6d3622014-11-24 14:58:31 +01003289}
3290
Michal Kaziord740d8f2015-03-30 09:51:51 +03003291static int ath10k_mac_tx_wmi_mgmt(struct ath10k *ar, struct sk_buff *skb)
Kalle Valo5e3dd152013-06-12 20:52:10 +03003292{
Michal Kaziord740d8f2015-03-30 09:51:51 +03003293 struct sk_buff_head *q = &ar->wmi_mgmt_tx_queue;
Bartosz Markowski5e00d312013-09-26 17:47:12 +02003294 int ret = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003295
Michal Kaziord740d8f2015-03-30 09:51:51 +03003296 spin_lock_bh(&ar->data_lock);
3297
3298 if (skb_queue_len(q) == ATH10K_MAX_NUM_MGMT_PENDING) {
3299 ath10k_warn(ar, "wmi mgmt tx queue is full\n");
3300 ret = -ENOSPC;
3301 goto unlock;
Michal Kazior961d4c32013-08-09 10:13:34 +02003302 }
3303
Michal Kaziord740d8f2015-03-30 09:51:51 +03003304 __skb_queue_tail(q, skb);
3305 ieee80211_queue_work(ar->hw, &ar->wmi_mgmt_tx_work);
3306
3307unlock:
3308 spin_unlock_bh(&ar->data_lock);
3309
3310 return ret;
3311}
3312
Michal Kazior8a933962015-11-18 06:59:17 +01003313static void ath10k_mac_tx(struct ath10k *ar, enum ath10k_hw_txrx_mode txmode,
3314 struct sk_buff *skb)
Michal Kaziord740d8f2015-03-30 09:51:51 +03003315{
Michal Kaziord740d8f2015-03-30 09:51:51 +03003316 struct ath10k_htt *htt = &ar->htt;
3317 int ret = 0;
3318
Michal Kazior8a933962015-11-18 06:59:17 +01003319 switch (txmode) {
Michal Kaziord740d8f2015-03-30 09:51:51 +03003320 case ATH10K_HW_TXRX_RAW:
3321 case ATH10K_HW_TXRX_NATIVE_WIFI:
3322 case ATH10K_HW_TXRX_ETHERNET:
Michal Kazior8a933962015-11-18 06:59:17 +01003323 ret = ath10k_htt_tx(htt, txmode, skb);
Michal Kaziord740d8f2015-03-30 09:51:51 +03003324 break;
3325 case ATH10K_HW_TXRX_MGMT:
Bartosz Markowski5e00d312013-09-26 17:47:12 +02003326 if (test_bit(ATH10K_FW_FEATURE_HAS_WMI_MGMT_TX,
Michal Kaziord740d8f2015-03-30 09:51:51 +03003327 ar->fw_features))
3328 ret = ath10k_mac_tx_wmi_mgmt(ar, skb);
3329 else if (ar->htt.target_version_major >= 3)
Michal Kazior8a933962015-11-18 06:59:17 +01003330 ret = ath10k_htt_tx(htt, txmode, skb);
Michal Kaziord740d8f2015-03-30 09:51:51 +03003331 else
3332 ret = ath10k_htt_mgmt_tx(htt, skb);
3333 break;
Bartosz Markowski5e00d312013-09-26 17:47:12 +02003334 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03003335
3336 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003337 ath10k_warn(ar, "failed to transmit packet, dropping: %d\n",
3338 ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003339 ieee80211_free_txskb(ar->hw, skb);
3340 }
3341}
3342
3343void ath10k_offchan_tx_purge(struct ath10k *ar)
3344{
3345 struct sk_buff *skb;
3346
3347 for (;;) {
3348 skb = skb_dequeue(&ar->offchan_tx_queue);
3349 if (!skb)
3350 break;
3351
3352 ieee80211_free_txskb(ar->hw, skb);
3353 }
3354}
3355
3356void ath10k_offchan_tx_work(struct work_struct *work)
3357{
3358 struct ath10k *ar = container_of(work, struct ath10k, offchan_tx_work);
3359 struct ath10k_peer *peer;
Michal Kazior8a933962015-11-18 06:59:17 +01003360 struct ath10k_vif *arvif;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003361 struct ieee80211_hdr *hdr;
Michal Kazior8a933962015-11-18 06:59:17 +01003362 struct ieee80211_vif *vif;
3363 struct ieee80211_sta *sta;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003364 struct sk_buff *skb;
3365 const u8 *peer_addr;
Michal Kazior8a933962015-11-18 06:59:17 +01003366 enum ath10k_hw_txrx_mode txmode;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003367 int vdev_id;
3368 int ret;
Nicholas Mc Guire8e9904f52015-03-30 15:39:19 +03003369 unsigned long time_left;
Michal Kazioradaeed72015-08-05 12:15:23 +02003370 bool tmp_peer_created = false;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003371
3372 /* FW requirement: We must create a peer before FW will send out
3373 * an offchannel frame. Otherwise the frame will be stuck and
3374 * never transmitted. We delete the peer upon tx completion.
3375 * It is unlikely that a peer for offchannel tx will already be
3376 * present. However it may be in some rare cases so account for that.
3377 * Otherwise we might remove a legitimate peer and break stuff. */
3378
3379 for (;;) {
3380 skb = skb_dequeue(&ar->offchan_tx_queue);
3381 if (!skb)
3382 break;
3383
3384 mutex_lock(&ar->conf_mutex);
3385
Michal Kazior7aa7a722014-08-25 12:09:38 +02003386 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac offchannel skb %p\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03003387 skb);
3388
3389 hdr = (struct ieee80211_hdr *)skb->data;
3390 peer_addr = ieee80211_get_DA(hdr);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003391
3392 spin_lock_bh(&ar->data_lock);
Michal Kazior609db222015-11-18 06:59:22 +01003393 vdev_id = ar->scan.vdev_id;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003394 peer = ath10k_peer_find(ar, vdev_id, peer_addr);
3395 spin_unlock_bh(&ar->data_lock);
3396
3397 if (peer)
Kalle Valo60c3daa2013-09-08 17:56:07 +03003398 /* FIXME: should this use ath10k_warn()? */
Michal Kazior7aa7a722014-08-25 12:09:38 +02003399 ath10k_dbg(ar, ATH10K_DBG_MAC, "peer %pM on vdev %d already present\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03003400 peer_addr, vdev_id);
3401
3402 if (!peer) {
Marek Puzyniak7390ed32015-03-30 09:51:52 +03003403 ret = ath10k_peer_create(ar, vdev_id, peer_addr,
3404 WMI_PEER_TYPE_DEFAULT);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003405 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003406 ath10k_warn(ar, "failed to create peer %pM on vdev %d: %d\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03003407 peer_addr, vdev_id, ret);
Michal Kazioradaeed72015-08-05 12:15:23 +02003408 tmp_peer_created = (ret == 0);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003409 }
3410
3411 spin_lock_bh(&ar->data_lock);
Wolfram Sang16735d02013-11-14 14:32:02 -08003412 reinit_completion(&ar->offchan_tx_completed);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003413 ar->offchan_tx_skb = skb;
3414 spin_unlock_bh(&ar->data_lock);
3415
Michal Kazior8a933962015-11-18 06:59:17 +01003416 /* It's safe to access vif and sta - conf_mutex guarantees that
3417 * sta_state() and remove_interface() are locked exclusively
3418 * out wrt to this offchannel worker.
3419 */
3420 arvif = ath10k_get_arvif(ar, vdev_id);
3421 if (arvif) {
3422 vif = arvif->vif;
3423 sta = ieee80211_find_sta(vif, peer_addr);
3424 } else {
3425 vif = NULL;
3426 sta = NULL;
3427 }
3428
3429 txmode = ath10k_mac_tx_h_get_txmode(ar, vif, sta, skb);
3430
3431 ath10k_mac_tx(ar, txmode, skb);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003432
Nicholas Mc Guire8e9904f52015-03-30 15:39:19 +03003433 time_left =
3434 wait_for_completion_timeout(&ar->offchan_tx_completed, 3 * HZ);
3435 if (time_left == 0)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003436 ath10k_warn(ar, "timed out waiting for offchannel skb %p\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03003437 skb);
3438
Michal Kazioradaeed72015-08-05 12:15:23 +02003439 if (!peer && tmp_peer_created) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03003440 ret = ath10k_peer_delete(ar, vdev_id, peer_addr);
3441 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003442 ath10k_warn(ar, "failed to delete peer %pM on vdev %d: %d\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03003443 peer_addr, vdev_id, ret);
3444 }
3445
3446 mutex_unlock(&ar->conf_mutex);
3447 }
3448}
3449
Bartosz Markowski5e00d312013-09-26 17:47:12 +02003450void ath10k_mgmt_over_wmi_tx_purge(struct ath10k *ar)
3451{
3452 struct sk_buff *skb;
3453
3454 for (;;) {
3455 skb = skb_dequeue(&ar->wmi_mgmt_tx_queue);
3456 if (!skb)
3457 break;
3458
3459 ieee80211_free_txskb(ar->hw, skb);
3460 }
3461}
3462
3463void ath10k_mgmt_over_wmi_tx_work(struct work_struct *work)
3464{
3465 struct ath10k *ar = container_of(work, struct ath10k, wmi_mgmt_tx_work);
3466 struct sk_buff *skb;
3467 int ret;
3468
3469 for (;;) {
3470 skb = skb_dequeue(&ar->wmi_mgmt_tx_queue);
3471 if (!skb)
3472 break;
3473
3474 ret = ath10k_wmi_mgmt_tx(ar, skb);
Michal Kazior5fb5e412013-10-28 07:18:13 +01003475 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003476 ath10k_warn(ar, "failed to transmit management frame via WMI: %d\n",
Kalle Valobe6546f2014-03-25 14:18:51 +02003477 ret);
Michal Kazior5fb5e412013-10-28 07:18:13 +01003478 ieee80211_free_txskb(ar->hw, skb);
3479 }
Bartosz Markowski5e00d312013-09-26 17:47:12 +02003480 }
3481}
3482
Kalle Valo5e3dd152013-06-12 20:52:10 +03003483/************/
3484/* Scanning */
3485/************/
3486
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003487void __ath10k_scan_finish(struct ath10k *ar)
Kalle Valo5e3dd152013-06-12 20:52:10 +03003488{
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003489 lockdep_assert_held(&ar->data_lock);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003490
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003491 switch (ar->scan.state) {
3492 case ATH10K_SCAN_IDLE:
3493 break;
3494 case ATH10K_SCAN_RUNNING:
Michal Kazior7305d3e2014-11-24 14:58:33 +01003495 case ATH10K_SCAN_ABORTING:
3496 if (!ar->scan.is_roc)
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003497 ieee80211_scan_completed(ar->hw,
3498 (ar->scan.state ==
3499 ATH10K_SCAN_ABORTING));
Michal Kaziord710e752015-07-09 13:08:36 +02003500 else if (ar->scan.roc_notify)
3501 ieee80211_remain_on_channel_expired(ar->hw);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003502 /* fall through */
3503 case ATH10K_SCAN_STARTING:
3504 ar->scan.state = ATH10K_SCAN_IDLE;
3505 ar->scan_channel = NULL;
Michal Kaziorbd877442015-11-18 06:59:19 +01003506 ar->scan.roc_freq = 0;
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003507 ath10k_offchan_tx_purge(ar);
3508 cancel_delayed_work(&ar->scan.timeout);
3509 complete_all(&ar->scan.completed);
3510 break;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003511 }
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003512}
Kalle Valo5e3dd152013-06-12 20:52:10 +03003513
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003514void ath10k_scan_finish(struct ath10k *ar)
3515{
3516 spin_lock_bh(&ar->data_lock);
3517 __ath10k_scan_finish(ar);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003518 spin_unlock_bh(&ar->data_lock);
3519}
3520
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003521static int ath10k_scan_stop(struct ath10k *ar)
Kalle Valo5e3dd152013-06-12 20:52:10 +03003522{
3523 struct wmi_stop_scan_arg arg = {
3524 .req_id = 1, /* FIXME */
3525 .req_type = WMI_SCAN_STOP_ONE,
3526 .u.scan_id = ATH10K_SCAN_ID,
3527 };
3528 int ret;
3529
3530 lockdep_assert_held(&ar->conf_mutex);
3531
Kalle Valo5e3dd152013-06-12 20:52:10 +03003532 ret = ath10k_wmi_stop_scan(ar, &arg);
3533 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003534 ath10k_warn(ar, "failed to stop wmi scan: %d\n", ret);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003535 goto out;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003536 }
3537
Kalle Valo5e3dd152013-06-12 20:52:10 +03003538 ret = wait_for_completion_timeout(&ar->scan.completed, 3*HZ);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003539 if (ret == 0) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003540 ath10k_warn(ar, "failed to receive scan abortion completion: timed out\n");
Kalle Valo5e3dd152013-06-12 20:52:10 +03003541 ret = -ETIMEDOUT;
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003542 } else if (ret > 0) {
3543 ret = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003544 }
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003545
3546out:
3547 /* Scan state should be updated upon scan completion but in case
3548 * firmware fails to deliver the event (for whatever reason) it is
3549 * desired to clean up scan state anyway. Firmware may have just
3550 * dropped the scan completion event delivery due to transport pipe
3551 * being overflown with data and/or it can recover on its own before
3552 * next scan request is submitted.
3553 */
3554 spin_lock_bh(&ar->data_lock);
3555 if (ar->scan.state != ATH10K_SCAN_IDLE)
3556 __ath10k_scan_finish(ar);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003557 spin_unlock_bh(&ar->data_lock);
3558
3559 return ret;
3560}
3561
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003562static void ath10k_scan_abort(struct ath10k *ar)
3563{
3564 int ret;
3565
3566 lockdep_assert_held(&ar->conf_mutex);
3567
3568 spin_lock_bh(&ar->data_lock);
3569
3570 switch (ar->scan.state) {
3571 case ATH10K_SCAN_IDLE:
3572 /* This can happen if timeout worker kicked in and called
3573 * abortion while scan completion was being processed.
3574 */
3575 break;
3576 case ATH10K_SCAN_STARTING:
3577 case ATH10K_SCAN_ABORTING:
Michal Kazior7aa7a722014-08-25 12:09:38 +02003578 ath10k_warn(ar, "refusing scan abortion due to invalid scan state: %s (%d)\n",
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003579 ath10k_scan_state_str(ar->scan.state),
3580 ar->scan.state);
3581 break;
3582 case ATH10K_SCAN_RUNNING:
3583 ar->scan.state = ATH10K_SCAN_ABORTING;
3584 spin_unlock_bh(&ar->data_lock);
3585
3586 ret = ath10k_scan_stop(ar);
3587 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003588 ath10k_warn(ar, "failed to abort scan: %d\n", ret);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003589
3590 spin_lock_bh(&ar->data_lock);
3591 break;
3592 }
3593
3594 spin_unlock_bh(&ar->data_lock);
3595}
3596
3597void ath10k_scan_timeout_work(struct work_struct *work)
3598{
3599 struct ath10k *ar = container_of(work, struct ath10k,
3600 scan.timeout.work);
3601
3602 mutex_lock(&ar->conf_mutex);
3603 ath10k_scan_abort(ar);
3604 mutex_unlock(&ar->conf_mutex);
3605}
3606
Kalle Valo5e3dd152013-06-12 20:52:10 +03003607static int ath10k_start_scan(struct ath10k *ar,
3608 const struct wmi_start_scan_arg *arg)
3609{
3610 int ret;
3611
3612 lockdep_assert_held(&ar->conf_mutex);
3613
3614 ret = ath10k_wmi_start_scan(ar, arg);
3615 if (ret)
3616 return ret;
3617
Kalle Valo5e3dd152013-06-12 20:52:10 +03003618 ret = wait_for_completion_timeout(&ar->scan.started, 1*HZ);
3619 if (ret == 0) {
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003620 ret = ath10k_scan_stop(ar);
3621 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003622 ath10k_warn(ar, "failed to stop scan: %d\n", ret);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003623
3624 return -ETIMEDOUT;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003625 }
3626
Ben Greear2f9eec02015-02-15 16:50:38 +02003627 /* If we failed to start the scan, return error code at
3628 * this point. This is probably due to some issue in the
3629 * firmware, but no need to wedge the driver due to that...
3630 */
3631 spin_lock_bh(&ar->data_lock);
3632 if (ar->scan.state == ATH10K_SCAN_IDLE) {
3633 spin_unlock_bh(&ar->data_lock);
3634 return -EINVAL;
3635 }
3636 spin_unlock_bh(&ar->data_lock);
3637
Kalle Valo5e3dd152013-06-12 20:52:10 +03003638 return 0;
3639}
3640
3641/**********************/
3642/* mac80211 callbacks */
3643/**********************/
3644
3645static void ath10k_tx(struct ieee80211_hw *hw,
3646 struct ieee80211_tx_control *control,
3647 struct sk_buff *skb)
3648{
Kalle Valo5e3dd152013-06-12 20:52:10 +03003649 struct ath10k *ar = hw->priv;
Michal Kazior66b8a012015-11-18 06:59:20 +01003650 struct ath10k_skb_cb *skb_cb = ATH10K_SKB_CB(skb);
Michal Kazior4b604552014-07-21 21:03:09 +03003651 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
3652 struct ieee80211_vif *vif = info->control.vif;
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03003653 struct ieee80211_sta *sta = control->sta;
Michal Kazior4b604552014-07-21 21:03:09 +03003654 struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data;
Michal Kazior8a933962015-11-18 06:59:17 +01003655 enum ath10k_hw_txrx_mode txmode;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003656
3657 /* We should disable CCK RATE due to P2P */
3658 if (info->flags & IEEE80211_TX_CTL_NO_CCK_RATE)
Michal Kazior7aa7a722014-08-25 12:09:38 +02003659 ath10k_dbg(ar, ATH10K_DBG_MAC, "IEEE80211_TX_CTL_NO_CCK_RATE\n");
Kalle Valo5e3dd152013-06-12 20:52:10 +03003660
Michal Kazior8a933962015-11-18 06:59:17 +01003661 txmode = ath10k_mac_tx_h_get_txmode(ar, vif, sta, skb);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003662
Michal Kazior66b8a012015-11-18 06:59:20 +01003663 skb_cb->flags = 0;
3664 if (!ath10k_tx_h_use_hwcrypto(vif, skb))
3665 skb_cb->flags |= ATH10K_SKB_F_NO_HWCRYPT;
3666
Michal Kaziord668dba2015-11-18 06:59:21 +01003667 if (ieee80211_is_mgmt(hdr->frame_control))
3668 skb_cb->flags |= ATH10K_SKB_F_MGMT;
3669
Michal Kazior609db222015-11-18 06:59:22 +01003670 if (ieee80211_is_data_qos(hdr->frame_control))
3671 skb_cb->flags |= ATH10K_SKB_F_QOS;
3672
3673 skb_cb->vif = vif;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003674
Michal Kazior8a933962015-11-18 06:59:17 +01003675 switch (txmode) {
Michal Kaziord740d8f2015-03-30 09:51:51 +03003676 case ATH10K_HW_TXRX_MGMT:
3677 case ATH10K_HW_TXRX_NATIVE_WIFI:
Michal Kazior4b604552014-07-21 21:03:09 +03003678 ath10k_tx_h_nwifi(hw, skb);
Michal Kazior4b604552014-07-21 21:03:09 +03003679 ath10k_tx_h_add_p2p_noa_ie(ar, vif, skb);
3680 ath10k_tx_h_seq_no(vif, skb);
Michal Kaziord740d8f2015-03-30 09:51:51 +03003681 break;
3682 case ATH10K_HW_TXRX_ETHERNET:
3683 ath10k_tx_h_8023(skb);
3684 break;
3685 case ATH10K_HW_TXRX_RAW:
David Liuccec9032015-07-24 20:25:32 +03003686 if (!test_bit(ATH10K_FLAG_RAW_MODE, &ar->dev_flags)) {
3687 WARN_ON_ONCE(1);
3688 ieee80211_free_txskb(hw, skb);
3689 return;
3690 }
Michal Kaziorcf84bd42013-07-16 11:04:54 +02003691 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03003692
Kalle Valo5e3dd152013-06-12 20:52:10 +03003693 if (info->flags & IEEE80211_TX_CTL_TX_OFFCHAN) {
Vasanthakumar Thiagarajan8921f5f2015-11-05 11:33:59 +05303694 if (!ath10k_mac_tx_frm_has_freq(ar)) {
Michal Kazior8d6d3622014-11-24 14:58:31 +01003695 ath10k_dbg(ar, ATH10K_DBG_MAC, "queued offchannel skb %p\n",
3696 skb);
3697
3698 skb_queue_tail(&ar->offchan_tx_queue, skb);
3699 ieee80211_queue_work(hw, &ar->offchan_tx_work);
3700 return;
3701 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03003702 }
3703
Michal Kazior8a933962015-11-18 06:59:17 +01003704 ath10k_mac_tx(ar, txmode, skb);
Kalle Valo5e3dd152013-06-12 20:52:10 +03003705}
3706
Michal Kaziorbca7baf2014-05-26 12:46:03 +03003707/* Must not be called with conf_mutex held as workers can use that also. */
Michal Kazior7962b0d2014-10-28 10:34:38 +01003708void ath10k_drain_tx(struct ath10k *ar)
Michal Kaziorbca7baf2014-05-26 12:46:03 +03003709{
3710 /* make sure rcu-protected mac80211 tx path itself is drained */
3711 synchronize_net();
3712
3713 ath10k_offchan_tx_purge(ar);
3714 ath10k_mgmt_over_wmi_tx_purge(ar);
3715
3716 cancel_work_sync(&ar->offchan_tx_work);
3717 cancel_work_sync(&ar->wmi_mgmt_tx_work);
3718}
3719
Michal Kazioraffd3212013-07-16 09:54:35 +02003720void ath10k_halt(struct ath10k *ar)
Michal Kazior818bdd12013-07-16 09:38:57 +02003721{
Michal Kaziord9bc4b92014-04-23 19:30:06 +03003722 struct ath10k_vif *arvif;
3723
Michal Kazior818bdd12013-07-16 09:38:57 +02003724 lockdep_assert_held(&ar->conf_mutex);
3725
Michal Kazior19337472014-08-28 12:58:16 +02003726 clear_bit(ATH10K_CAC_RUNNING, &ar->dev_flags);
3727 ar->filter_flags = 0;
3728 ar->monitor = false;
Michal Kazior500ff9f2015-03-31 10:26:21 +00003729 ar->monitor_arvif = NULL;
Michal Kazior19337472014-08-28 12:58:16 +02003730
3731 if (ar->monitor_started)
Michal Kazior1bbc0972014-04-08 09:45:47 +03003732 ath10k_monitor_stop(ar);
Michal Kazior19337472014-08-28 12:58:16 +02003733
3734 ar->monitor_started = false;
Michal Kazior96d828d2015-03-31 10:26:23 +00003735 ar->tx_paused = 0;
Michal Kazior1bbc0972014-04-08 09:45:47 +03003736
Michal Kazior5c81c7f2014-08-05 14:54:44 +02003737 ath10k_scan_finish(ar);
Michal Kazior818bdd12013-07-16 09:38:57 +02003738 ath10k_peer_cleanup_all(ar);
3739 ath10k_core_stop(ar);
3740 ath10k_hif_power_down(ar);
3741
3742 spin_lock_bh(&ar->data_lock);
Michal Kazior64badcb2014-09-18 11:18:02 +03003743 list_for_each_entry(arvif, &ar->arvifs, list)
3744 ath10k_mac_vif_beacon_cleanup(arvif);
Michal Kazior818bdd12013-07-16 09:38:57 +02003745 spin_unlock_bh(&ar->data_lock);
3746}
3747
Ben Greear46acf7b2014-05-16 17:15:38 +03003748static int ath10k_get_antenna(struct ieee80211_hw *hw, u32 *tx_ant, u32 *rx_ant)
3749{
3750 struct ath10k *ar = hw->priv;
3751
3752 mutex_lock(&ar->conf_mutex);
3753
Rajkumar Manoharan166de3f2015-10-27 17:51:11 +05303754 *tx_ant = ar->cfg_tx_chainmask;
3755 *rx_ant = ar->cfg_rx_chainmask;
Ben Greear46acf7b2014-05-16 17:15:38 +03003756
3757 mutex_unlock(&ar->conf_mutex);
3758
3759 return 0;
3760}
3761
Ben Greear5572a952014-11-24 16:22:10 +02003762static void ath10k_check_chain_mask(struct ath10k *ar, u32 cm, const char *dbg)
3763{
3764 /* It is not clear that allowing gaps in chainmask
3765 * is helpful. Probably it will not do what user
3766 * is hoping for, so warn in that case.
3767 */
3768 if (cm == 15 || cm == 7 || cm == 3 || cm == 1 || cm == 0)
3769 return;
3770
3771 ath10k_warn(ar, "mac %s antenna chainmask may be invalid: 0x%x. Suggested values: 15, 7, 3, 1 or 0.\n",
3772 dbg, cm);
3773}
3774
Rajkumar Manoharanf58512f2015-10-27 17:51:13 +05303775static int ath10k_mac_get_vht_cap_bf_sts(struct ath10k *ar)
3776{
3777 int nsts = ar->vht_cap_info;
3778
3779 nsts &= IEEE80211_VHT_CAP_BEAMFORMEE_STS_MASK;
3780 nsts >>= IEEE80211_VHT_CAP_BEAMFORMEE_STS_SHIFT;
3781
3782 /* If firmware does not deliver to host number of space-time
3783 * streams supported, assume it support up to 4 BF STS and return
3784 * the value for VHT CAP: nsts-1)
3785 */
3786 if (nsts == 0)
3787 return 3;
3788
3789 return nsts;
3790}
3791
3792static int ath10k_mac_get_vht_cap_bf_sound_dim(struct ath10k *ar)
3793{
3794 int sound_dim = ar->vht_cap_info;
3795
3796 sound_dim &= IEEE80211_VHT_CAP_SOUNDING_DIMENSIONS_MASK;
3797 sound_dim >>= IEEE80211_VHT_CAP_SOUNDING_DIMENSIONS_SHIFT;
3798
3799 /* If the sounding dimension is not advertised by the firmware,
3800 * let's use a default value of 1
3801 */
3802 if (sound_dim == 0)
3803 return 1;
3804
3805 return sound_dim;
3806}
3807
3808static struct ieee80211_sta_vht_cap ath10k_create_vht_cap(struct ath10k *ar)
3809{
3810 struct ieee80211_sta_vht_cap vht_cap = {0};
3811 u16 mcs_map;
3812 u32 val;
3813 int i;
3814
3815 vht_cap.vht_supported = 1;
3816 vht_cap.cap = ar->vht_cap_info;
3817
3818 if (ar->vht_cap_info & (IEEE80211_VHT_CAP_SU_BEAMFORMEE_CAPABLE |
3819 IEEE80211_VHT_CAP_MU_BEAMFORMEE_CAPABLE)) {
3820 val = ath10k_mac_get_vht_cap_bf_sts(ar);
3821 val <<= IEEE80211_VHT_CAP_BEAMFORMEE_STS_SHIFT;
3822 val &= IEEE80211_VHT_CAP_BEAMFORMEE_STS_MASK;
3823
3824 vht_cap.cap |= val;
3825 }
3826
3827 if (ar->vht_cap_info & (IEEE80211_VHT_CAP_SU_BEAMFORMER_CAPABLE |
3828 IEEE80211_VHT_CAP_MU_BEAMFORMER_CAPABLE)) {
3829 val = ath10k_mac_get_vht_cap_bf_sound_dim(ar);
3830 val <<= IEEE80211_VHT_CAP_SOUNDING_DIMENSIONS_SHIFT;
3831 val &= IEEE80211_VHT_CAP_SOUNDING_DIMENSIONS_MASK;
3832
3833 vht_cap.cap |= val;
3834 }
3835
3836 mcs_map = 0;
3837 for (i = 0; i < 8; i++) {
3838 if ((i < ar->num_rf_chains) && (ar->cfg_tx_chainmask & BIT(i)))
3839 mcs_map |= IEEE80211_VHT_MCS_SUPPORT_0_9 << (i * 2);
3840 else
3841 mcs_map |= IEEE80211_VHT_MCS_NOT_SUPPORTED << (i * 2);
3842 }
3843
3844 vht_cap.vht_mcs.rx_mcs_map = cpu_to_le16(mcs_map);
3845 vht_cap.vht_mcs.tx_mcs_map = cpu_to_le16(mcs_map);
3846
3847 return vht_cap;
3848}
3849
3850static struct ieee80211_sta_ht_cap ath10k_get_ht_cap(struct ath10k *ar)
3851{
3852 int i;
3853 struct ieee80211_sta_ht_cap ht_cap = {0};
3854
3855 if (!(ar->ht_cap_info & WMI_HT_CAP_ENABLED))
3856 return ht_cap;
3857
3858 ht_cap.ht_supported = 1;
3859 ht_cap.ampdu_factor = IEEE80211_HT_MAX_AMPDU_64K;
3860 ht_cap.ampdu_density = IEEE80211_HT_MPDU_DENSITY_8;
3861 ht_cap.cap |= IEEE80211_HT_CAP_SUP_WIDTH_20_40;
3862 ht_cap.cap |= IEEE80211_HT_CAP_DSSSCCK40;
Peter Ohe33a99e2015-12-31 15:26:20 +02003863 ht_cap.cap |=
3864 WLAN_HT_CAP_SM_PS_DISABLED << IEEE80211_HT_CAP_SM_PS_SHIFT;
Rajkumar Manoharanf58512f2015-10-27 17:51:13 +05303865
3866 if (ar->ht_cap_info & WMI_HT_CAP_HT20_SGI)
3867 ht_cap.cap |= IEEE80211_HT_CAP_SGI_20;
3868
3869 if (ar->ht_cap_info & WMI_HT_CAP_HT40_SGI)
3870 ht_cap.cap |= IEEE80211_HT_CAP_SGI_40;
3871
3872 if (ar->ht_cap_info & WMI_HT_CAP_DYNAMIC_SMPS) {
3873 u32 smps;
3874
3875 smps = WLAN_HT_CAP_SM_PS_DYNAMIC;
3876 smps <<= IEEE80211_HT_CAP_SM_PS_SHIFT;
3877
3878 ht_cap.cap |= smps;
3879 }
3880
3881 if (ar->ht_cap_info & WMI_HT_CAP_TX_STBC)
3882 ht_cap.cap |= IEEE80211_HT_CAP_TX_STBC;
3883
3884 if (ar->ht_cap_info & WMI_HT_CAP_RX_STBC) {
3885 u32 stbc;
3886
3887 stbc = ar->ht_cap_info;
3888 stbc &= WMI_HT_CAP_RX_STBC;
3889 stbc >>= WMI_HT_CAP_RX_STBC_MASK_SHIFT;
3890 stbc <<= IEEE80211_HT_CAP_RX_STBC_SHIFT;
3891 stbc &= IEEE80211_HT_CAP_RX_STBC;
3892
3893 ht_cap.cap |= stbc;
3894 }
3895
3896 if (ar->ht_cap_info & WMI_HT_CAP_LDPC)
3897 ht_cap.cap |= IEEE80211_HT_CAP_LDPC_CODING;
3898
3899 if (ar->ht_cap_info & WMI_HT_CAP_L_SIG_TXOP_PROT)
3900 ht_cap.cap |= IEEE80211_HT_CAP_LSIG_TXOP_PROT;
3901
3902 /* max AMSDU is implicitly taken from vht_cap_info */
3903 if (ar->vht_cap_info & WMI_VHT_CAP_MAX_MPDU_LEN_MASK)
3904 ht_cap.cap |= IEEE80211_HT_CAP_MAX_AMSDU;
3905
3906 for (i = 0; i < ar->num_rf_chains; i++) {
3907 if (ar->cfg_rx_chainmask & BIT(i))
3908 ht_cap.mcs.rx_mask[i] = 0xFF;
3909 }
3910
3911 ht_cap.mcs.tx_params |= IEEE80211_HT_MCS_TX_DEFINED;
3912
3913 return ht_cap;
3914}
3915
Rajkumar Manoharan5036fe02015-10-27 17:51:14 +05303916static void ath10k_mac_setup_ht_vht_cap(struct ath10k *ar)
3917{
3918 struct ieee80211_supported_band *band;
3919 struct ieee80211_sta_vht_cap vht_cap;
3920 struct ieee80211_sta_ht_cap ht_cap;
3921
3922 ht_cap = ath10k_get_ht_cap(ar);
3923 vht_cap = ath10k_create_vht_cap(ar);
3924
3925 if (ar->phy_capability & WHAL_WLAN_11G_CAPABILITY) {
3926 band = &ar->mac.sbands[IEEE80211_BAND_2GHZ];
3927 band->ht_cap = ht_cap;
3928
3929 /* Enable the VHT support at 2.4 GHz */
3930 band->vht_cap = vht_cap;
3931 }
3932 if (ar->phy_capability & WHAL_WLAN_11A_CAPABILITY) {
3933 band = &ar->mac.sbands[IEEE80211_BAND_5GHZ];
3934 band->ht_cap = ht_cap;
3935 band->vht_cap = vht_cap;
3936 }
3937}
3938
Ben Greear46acf7b2014-05-16 17:15:38 +03003939static int __ath10k_set_antenna(struct ath10k *ar, u32 tx_ant, u32 rx_ant)
3940{
3941 int ret;
3942
3943 lockdep_assert_held(&ar->conf_mutex);
3944
Ben Greear5572a952014-11-24 16:22:10 +02003945 ath10k_check_chain_mask(ar, tx_ant, "tx");
3946 ath10k_check_chain_mask(ar, rx_ant, "rx");
3947
Ben Greear46acf7b2014-05-16 17:15:38 +03003948 ar->cfg_tx_chainmask = tx_ant;
3949 ar->cfg_rx_chainmask = rx_ant;
3950
3951 if ((ar->state != ATH10K_STATE_ON) &&
3952 (ar->state != ATH10K_STATE_RESTARTED))
3953 return 0;
3954
3955 ret = ath10k_wmi_pdev_set_param(ar, ar->wmi.pdev_param->tx_chain_mask,
3956 tx_ant);
3957 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003958 ath10k_warn(ar, "failed to set tx-chainmask: %d, req 0x%x\n",
Ben Greear46acf7b2014-05-16 17:15:38 +03003959 ret, tx_ant);
3960 return ret;
3961 }
3962
3963 ret = ath10k_wmi_pdev_set_param(ar, ar->wmi.pdev_param->rx_chain_mask,
3964 rx_ant);
3965 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02003966 ath10k_warn(ar, "failed to set rx-chainmask: %d, req 0x%x\n",
Ben Greear46acf7b2014-05-16 17:15:38 +03003967 ret, rx_ant);
3968 return ret;
3969 }
3970
Rajkumar Manoharan5036fe02015-10-27 17:51:14 +05303971 /* Reload HT/VHT capability */
3972 ath10k_mac_setup_ht_vht_cap(ar);
3973
Ben Greear46acf7b2014-05-16 17:15:38 +03003974 return 0;
3975}
3976
3977static int ath10k_set_antenna(struct ieee80211_hw *hw, u32 tx_ant, u32 rx_ant)
3978{
3979 struct ath10k *ar = hw->priv;
3980 int ret;
3981
3982 mutex_lock(&ar->conf_mutex);
3983 ret = __ath10k_set_antenna(ar, tx_ant, rx_ant);
3984 mutex_unlock(&ar->conf_mutex);
3985 return ret;
3986}
3987
Kalle Valo5e3dd152013-06-12 20:52:10 +03003988static int ath10k_start(struct ieee80211_hw *hw)
3989{
3990 struct ath10k *ar = hw->priv;
Janusz Dziedzic24ab13e2015-04-01 22:53:18 +03003991 u32 burst_enable;
Michal Kazior818bdd12013-07-16 09:38:57 +02003992 int ret = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03003993
Michal Kaziorbca7baf2014-05-26 12:46:03 +03003994 /*
3995 * This makes sense only when restarting hw. It is harmless to call
3996 * uncoditionally. This is necessary to make sure no HTT/WMI tx
3997 * commands will be submitted while restarting.
3998 */
3999 ath10k_drain_tx(ar);
4000
Michal Kazior548db542013-07-05 16:15:15 +03004001 mutex_lock(&ar->conf_mutex);
4002
Michal Kaziorc5058f52014-05-26 12:46:03 +03004003 switch (ar->state) {
4004 case ATH10K_STATE_OFF:
4005 ar->state = ATH10K_STATE_ON;
4006 break;
4007 case ATH10K_STATE_RESTARTING:
4008 ath10k_halt(ar);
4009 ar->state = ATH10K_STATE_RESTARTED;
4010 break;
4011 case ATH10K_STATE_ON:
4012 case ATH10K_STATE_RESTARTED:
4013 case ATH10K_STATE_WEDGED:
4014 WARN_ON(1);
Michal Kazior818bdd12013-07-16 09:38:57 +02004015 ret = -EINVAL;
Michal Kaziorae254432014-05-26 12:46:02 +03004016 goto err;
Kalle Valo43d2a302014-09-10 18:23:30 +03004017 case ATH10K_STATE_UTF:
4018 ret = -EBUSY;
4019 goto err;
Michal Kazior818bdd12013-07-16 09:38:57 +02004020 }
4021
4022 ret = ath10k_hif_power_up(ar);
4023 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004024 ath10k_err(ar, "Could not init hif: %d\n", ret);
Michal Kaziorae254432014-05-26 12:46:02 +03004025 goto err_off;
Michal Kazior818bdd12013-07-16 09:38:57 +02004026 }
4027
Kalle Valo43d2a302014-09-10 18:23:30 +03004028 ret = ath10k_core_start(ar, ATH10K_FIRMWARE_MODE_NORMAL);
Michal Kazior818bdd12013-07-16 09:38:57 +02004029 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004030 ath10k_err(ar, "Could not init core: %d\n", ret);
Michal Kaziorae254432014-05-26 12:46:02 +03004031 goto err_power_down;
Michal Kazior818bdd12013-07-16 09:38:57 +02004032 }
4033
Bartosz Markowski226a3392013-09-26 17:47:16 +02004034 ret = ath10k_wmi_pdev_set_param(ar, ar->wmi.pdev_param->pmf_qos, 1);
Michal Kaziorae254432014-05-26 12:46:02 +03004035 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004036 ath10k_warn(ar, "failed to enable PMF QOS: %d\n", ret);
Michal Kaziorae254432014-05-26 12:46:02 +03004037 goto err_core_stop;
4038 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004039
Michal Kaziorc4dd0d02013-11-13 11:05:10 +01004040 ret = ath10k_wmi_pdev_set_param(ar, ar->wmi.pdev_param->dynamic_bw, 1);
Michal Kaziorae254432014-05-26 12:46:02 +03004041 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004042 ath10k_warn(ar, "failed to enable dynamic BW: %d\n", ret);
Michal Kaziorae254432014-05-26 12:46:02 +03004043 goto err_core_stop;
4044 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004045
Michal Kaziorcf327842015-03-31 10:26:25 +00004046 if (test_bit(WMI_SERVICE_ADAPTIVE_OCS, ar->wmi.svc_map)) {
4047 ret = ath10k_wmi_adaptive_qcs(ar, true);
4048 if (ret) {
4049 ath10k_warn(ar, "failed to enable adaptive qcs: %d\n",
4050 ret);
4051 goto err_core_stop;
4052 }
4053 }
4054
Janusz Dziedzic24ab13e2015-04-01 22:53:18 +03004055 if (test_bit(WMI_SERVICE_BURST, ar->wmi.svc_map)) {
4056 burst_enable = ar->wmi.pdev_param->burst_enable;
4057 ret = ath10k_wmi_pdev_set_param(ar, burst_enable, 0);
4058 if (ret) {
4059 ath10k_warn(ar, "failed to disable burst: %d\n", ret);
4060 goto err_core_stop;
4061 }
4062 }
4063
Rajkumar Manoharan166de3f2015-10-27 17:51:11 +05304064 __ath10k_set_antenna(ar, ar->cfg_tx_chainmask, ar->cfg_rx_chainmask);
Ben Greear46acf7b2014-05-16 17:15:38 +03004065
Marek Puzyniakab6258e2014-01-29 15:03:31 +02004066 /*
4067 * By default FW set ARP frames ac to voice (6). In that case ARP
4068 * exchange is not working properly for UAPSD enabled AP. ARP requests
4069 * which arrives with access category 0 are processed by network stack
4070 * and send back with access category 0, but FW changes access category
4071 * to 6. Set ARP frames access category to best effort (0) solves
4072 * this problem.
4073 */
4074
4075 ret = ath10k_wmi_pdev_set_param(ar,
4076 ar->wmi.pdev_param->arp_ac_override, 0);
4077 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004078 ath10k_warn(ar, "failed to set arp ac override parameter: %d\n",
Marek Puzyniakab6258e2014-01-29 15:03:31 +02004079 ret);
Michal Kaziorae254432014-05-26 12:46:02 +03004080 goto err_core_stop;
Marek Puzyniakab6258e2014-01-29 15:03:31 +02004081 }
4082
Maharaja62f77f02015-10-21 11:49:18 +03004083 if (test_bit(ATH10K_FW_FEATURE_SUPPORTS_ADAPTIVE_CCA,
4084 ar->fw_features)) {
4085 ret = ath10k_wmi_pdev_enable_adaptive_cca(ar, 1,
4086 WMI_CCA_DETECT_LEVEL_AUTO,
4087 WMI_CCA_DETECT_MARGIN_AUTO);
4088 if (ret) {
4089 ath10k_warn(ar, "failed to enable adaptive cca: %d\n",
4090 ret);
4091 goto err_core_stop;
4092 }
4093 }
4094
Ashok Raj Nagarajan575f1c32015-03-19 16:37:59 +05304095 ret = ath10k_wmi_pdev_set_param(ar,
4096 ar->wmi.pdev_param->ani_enable, 1);
4097 if (ret) {
4098 ath10k_warn(ar, "failed to enable ani by default: %d\n",
4099 ret);
4100 goto err_core_stop;
4101 }
4102
Ashok Raj Nagarajanb3e71d72015-03-19 16:38:00 +05304103 ar->ani_enabled = true;
4104
Michal Kaziord6500972014-04-08 09:56:09 +03004105 ar->num_started_vdevs = 0;
Michal Kaziorf7843d72013-07-16 09:38:52 +02004106 ath10k_regd_update(ar);
4107
Simon Wunderlich855aed12014-08-02 09:12:54 +03004108 ath10k_spectral_start(ar);
Rajkumar Manoharan8515b5c2015-03-15 20:36:22 +05304109 ath10k_thermal_set_throttling(ar);
Simon Wunderlich855aed12014-08-02 09:12:54 +03004110
Michal Kaziorae254432014-05-26 12:46:02 +03004111 mutex_unlock(&ar->conf_mutex);
4112 return 0;
4113
4114err_core_stop:
4115 ath10k_core_stop(ar);
4116
4117err_power_down:
4118 ath10k_hif_power_down(ar);
4119
4120err_off:
4121 ar->state = ATH10K_STATE_OFF;
4122
4123err:
Michal Kazior548db542013-07-05 16:15:15 +03004124 mutex_unlock(&ar->conf_mutex);
Michal Kaziorc60bdd82014-01-29 07:26:31 +01004125 return ret;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004126}
4127
4128static void ath10k_stop(struct ieee80211_hw *hw)
4129{
4130 struct ath10k *ar = hw->priv;
4131
Michal Kaziorbca7baf2014-05-26 12:46:03 +03004132 ath10k_drain_tx(ar);
4133
Michal Kazior548db542013-07-05 16:15:15 +03004134 mutex_lock(&ar->conf_mutex);
Michal Kaziorc5058f52014-05-26 12:46:03 +03004135 if (ar->state != ATH10K_STATE_OFF) {
Michal Kazior818bdd12013-07-16 09:38:57 +02004136 ath10k_halt(ar);
Michal Kaziorc5058f52014-05-26 12:46:03 +03004137 ar->state = ATH10K_STATE_OFF;
4138 }
Michal Kazior548db542013-07-05 16:15:15 +03004139 mutex_unlock(&ar->conf_mutex);
4140
Michal Kazior5c81c7f2014-08-05 14:54:44 +02004141 cancel_delayed_work_sync(&ar->scan.timeout);
Michal Kazioraffd3212013-07-16 09:54:35 +02004142 cancel_work_sync(&ar->restart_work);
4143}
4144
Michal Kaziorad088bf2013-10-16 15:44:46 +03004145static int ath10k_config_ps(struct ath10k *ar)
Michal Kazioraffd3212013-07-16 09:54:35 +02004146{
Michal Kaziorad088bf2013-10-16 15:44:46 +03004147 struct ath10k_vif *arvif;
4148 int ret = 0;
Michal Kazioraffd3212013-07-16 09:54:35 +02004149
4150 lockdep_assert_held(&ar->conf_mutex);
4151
Michal Kaziorad088bf2013-10-16 15:44:46 +03004152 list_for_each_entry(arvif, &ar->arvifs, list) {
4153 ret = ath10k_mac_vif_setup_ps(arvif);
4154 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004155 ath10k_warn(ar, "failed to setup powersave: %d\n", ret);
Michal Kaziorad088bf2013-10-16 15:44:46 +03004156 break;
4157 }
4158 }
Michal Kazioraffd3212013-07-16 09:54:35 +02004159
Michal Kaziorad088bf2013-10-16 15:44:46 +03004160 return ret;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004161}
4162
Michal Kazior7d9d5582014-10-21 10:40:15 +03004163static int ath10k_mac_txpower_setup(struct ath10k *ar, int txpower)
4164{
4165 int ret;
4166 u32 param;
4167
4168 lockdep_assert_held(&ar->conf_mutex);
4169
4170 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac txpower %d\n", txpower);
4171
4172 param = ar->wmi.pdev_param->txpower_limit2g;
4173 ret = ath10k_wmi_pdev_set_param(ar, param, txpower * 2);
4174 if (ret) {
4175 ath10k_warn(ar, "failed to set 2g txpower %d: %d\n",
4176 txpower, ret);
4177 return ret;
4178 }
4179
4180 param = ar->wmi.pdev_param->txpower_limit5g;
4181 ret = ath10k_wmi_pdev_set_param(ar, param, txpower * 2);
4182 if (ret) {
4183 ath10k_warn(ar, "failed to set 5g txpower %d: %d\n",
4184 txpower, ret);
4185 return ret;
4186 }
4187
4188 return 0;
4189}
4190
4191static int ath10k_mac_txpower_recalc(struct ath10k *ar)
4192{
4193 struct ath10k_vif *arvif;
4194 int ret, txpower = -1;
4195
4196 lockdep_assert_held(&ar->conf_mutex);
4197
4198 list_for_each_entry(arvif, &ar->arvifs, list) {
4199 WARN_ON(arvif->txpower < 0);
4200
4201 if (txpower == -1)
4202 txpower = arvif->txpower;
4203 else
4204 txpower = min(txpower, arvif->txpower);
4205 }
4206
4207 if (WARN_ON(txpower == -1))
4208 return -EINVAL;
4209
4210 ret = ath10k_mac_txpower_setup(ar, txpower);
4211 if (ret) {
4212 ath10k_warn(ar, "failed to setup tx power %d: %d\n",
4213 txpower, ret);
4214 return ret;
4215 }
4216
4217 return 0;
4218}
4219
Kalle Valo5e3dd152013-06-12 20:52:10 +03004220static int ath10k_config(struct ieee80211_hw *hw, u32 changed)
4221{
Kalle Valo5e3dd152013-06-12 20:52:10 +03004222 struct ath10k *ar = hw->priv;
4223 struct ieee80211_conf *conf = &hw->conf;
4224 int ret = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004225
4226 mutex_lock(&ar->conf_mutex);
4227
Michal Kazioraffd3212013-07-16 09:54:35 +02004228 if (changed & IEEE80211_CONF_CHANGE_PS)
4229 ath10k_config_ps(ar);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004230
4231 if (changed & IEEE80211_CONF_CHANGE_MONITOR) {
Michal Kazior19337472014-08-28 12:58:16 +02004232 ar->monitor = conf->flags & IEEE80211_CONF_MONITOR;
4233 ret = ath10k_monitor_recalc(ar);
4234 if (ret)
4235 ath10k_warn(ar, "failed to recalc monitor: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004236 }
4237
4238 mutex_unlock(&ar->conf_mutex);
4239 return ret;
4240}
4241
Ben Greear5572a952014-11-24 16:22:10 +02004242static u32 get_nss_from_chainmask(u16 chain_mask)
4243{
Rajkumar Manoharanf680f702015-11-03 11:51:33 +05304244 if ((chain_mask & 0xf) == 0xf)
Ben Greear5572a952014-11-24 16:22:10 +02004245 return 4;
4246 else if ((chain_mask & 0x7) == 0x7)
4247 return 3;
4248 else if ((chain_mask & 0x3) == 0x3)
4249 return 2;
4250 return 1;
4251}
4252
Vivek Natarajana48e2cc2015-08-04 10:45:12 +05304253static int ath10k_mac_set_txbf_conf(struct ath10k_vif *arvif)
4254{
4255 u32 value = 0;
4256 struct ath10k *ar = arvif->ar;
Bartosz Markowski707a0c82015-09-02 13:20:19 +02004257 int nsts;
Bartosz Markowski0c6d6f22015-09-02 13:20:20 +02004258 int sound_dim;
Vivek Natarajana48e2cc2015-08-04 10:45:12 +05304259
4260 if (ath10k_wmi_get_txbf_conf_scheme(ar) != WMI_TXBF_CONF_BEFORE_ASSOC)
4261 return 0;
4262
Bartosz Markowski707a0c82015-09-02 13:20:19 +02004263 nsts = ath10k_mac_get_vht_cap_bf_sts(ar);
Vivek Natarajana48e2cc2015-08-04 10:45:12 +05304264 if (ar->vht_cap_info & (IEEE80211_VHT_CAP_SU_BEAMFORMEE_CAPABLE |
4265 IEEE80211_VHT_CAP_MU_BEAMFORMEE_CAPABLE))
Bartosz Markowski707a0c82015-09-02 13:20:19 +02004266 value |= SM(nsts, WMI_TXBF_STS_CAP_OFFSET);
Vivek Natarajana48e2cc2015-08-04 10:45:12 +05304267
Bartosz Markowski0c6d6f22015-09-02 13:20:20 +02004268 sound_dim = ath10k_mac_get_vht_cap_bf_sound_dim(ar);
Vivek Natarajana48e2cc2015-08-04 10:45:12 +05304269 if (ar->vht_cap_info & (IEEE80211_VHT_CAP_SU_BEAMFORMER_CAPABLE |
4270 IEEE80211_VHT_CAP_MU_BEAMFORMER_CAPABLE))
Bartosz Markowski0c6d6f22015-09-02 13:20:20 +02004271 value |= SM(sound_dim, WMI_BF_SOUND_DIM_OFFSET);
Vivek Natarajana48e2cc2015-08-04 10:45:12 +05304272
4273 if (!value)
4274 return 0;
4275
4276 if (ar->vht_cap_info & IEEE80211_VHT_CAP_SU_BEAMFORMER_CAPABLE)
4277 value |= WMI_VDEV_PARAM_TXBF_SU_TX_BFER;
4278
4279 if (ar->vht_cap_info & IEEE80211_VHT_CAP_MU_BEAMFORMER_CAPABLE)
4280 value |= (WMI_VDEV_PARAM_TXBF_MU_TX_BFER |
4281 WMI_VDEV_PARAM_TXBF_SU_TX_BFER);
4282
4283 if (ar->vht_cap_info & IEEE80211_VHT_CAP_SU_BEAMFORMEE_CAPABLE)
4284 value |= WMI_VDEV_PARAM_TXBF_SU_TX_BFEE;
4285
4286 if (ar->vht_cap_info & IEEE80211_VHT_CAP_MU_BEAMFORMEE_CAPABLE)
4287 value |= (WMI_VDEV_PARAM_TXBF_MU_TX_BFEE |
4288 WMI_VDEV_PARAM_TXBF_SU_TX_BFEE);
4289
4290 return ath10k_wmi_vdev_set_param(ar, arvif->vdev_id,
4291 ar->wmi.vdev_param->txbf, value);
4292}
4293
Kalle Valo5e3dd152013-06-12 20:52:10 +03004294/*
4295 * TODO:
4296 * Figure out how to handle WMI_VDEV_SUBTYPE_P2P_DEVICE,
4297 * because we will send mgmt frames without CCK. This requirement
4298 * for P2P_FIND/GO_NEG should be handled by checking CCK flag
4299 * in the TX packet.
4300 */
4301static int ath10k_add_interface(struct ieee80211_hw *hw,
4302 struct ieee80211_vif *vif)
4303{
4304 struct ath10k *ar = hw->priv;
4305 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
4306 enum wmi_sta_powersave_param param;
4307 int ret = 0;
Kalle Valo5a13e762014-01-20 11:01:46 +02004308 u32 value;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004309 int bit;
Michal Kazior96d828d2015-03-31 10:26:23 +00004310 int i;
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02004311 u32 vdev_param;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004312
Johannes Berg848955c2014-11-11 12:48:42 +01004313 vif->driver_flags |= IEEE80211_VIF_SUPPORTS_UAPSD;
4314
Kalle Valo5e3dd152013-06-12 20:52:10 +03004315 mutex_lock(&ar->conf_mutex);
4316
Michal Kazior0dbd09e2013-07-31 10:55:14 +02004317 memset(arvif, 0, sizeof(*arvif));
4318
Kalle Valo5e3dd152013-06-12 20:52:10 +03004319 arvif->ar = ar;
4320 arvif->vif = vif;
4321
Ben Greeare63b33f2013-10-22 14:54:14 -07004322 INIT_LIST_HEAD(&arvif->list);
Michal Kazior81a9a172015-03-05 16:02:17 +02004323 INIT_WORK(&arvif->ap_csa_work, ath10k_mac_vif_ap_csa_work);
Michal Kaziorcc9904e2015-03-10 16:22:01 +02004324 INIT_DELAYED_WORK(&arvif->connection_loss_work,
4325 ath10k_mac_vif_sta_connection_loss_work);
Michal Kaziorcc4827b2013-10-16 15:44:45 +03004326
Michal Kazior45c9abc2015-04-21 20:42:58 +03004327 for (i = 0; i < ARRAY_SIZE(arvif->bitrate_mask.control); i++) {
4328 arvif->bitrate_mask.control[i].legacy = 0xffffffff;
4329 memset(arvif->bitrate_mask.control[i].ht_mcs, 0xff,
4330 sizeof(arvif->bitrate_mask.control[i].ht_mcs));
4331 memset(arvif->bitrate_mask.control[i].vht_mcs, 0xff,
4332 sizeof(arvif->bitrate_mask.control[i].vht_mcs));
4333 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004334
Michal Kaziore04cafb2015-08-05 12:15:24 +02004335 if (ar->num_peers >= ar->max_num_peers) {
4336 ath10k_warn(ar, "refusing vdev creation due to insufficient peer entry resources in firmware\n");
Michal Kazior503422d2015-08-19 13:08:53 +02004337 ret = -ENOBUFS;
4338 goto err;
Michal Kaziore04cafb2015-08-05 12:15:24 +02004339 }
4340
Ben Greeara9aefb32014-08-12 11:02:19 +03004341 if (ar->free_vdev_map == 0) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004342 ath10k_warn(ar, "Free vdev map is empty, no more interfaces allowed.\n");
Kalle Valo5e3dd152013-06-12 20:52:10 +03004343 ret = -EBUSY;
Michal Kazior9dad14a2013-10-16 15:44:45 +03004344 goto err;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004345 }
Ben Greear16c11172014-09-23 14:17:16 -07004346 bit = __ffs64(ar->free_vdev_map);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004347
Ben Greear16c11172014-09-23 14:17:16 -07004348 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac create vdev %i map %llx\n",
4349 bit, ar->free_vdev_map);
4350
4351 arvif->vdev_id = bit;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004352 arvif->vdev_subtype = WMI_VDEV_SUBTYPE_NONE;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004353
Kalle Valo5e3dd152013-06-12 20:52:10 +03004354 switch (vif->type) {
Michal Kazior75d2bd42014-12-12 12:41:39 +01004355 case NL80211_IFTYPE_P2P_DEVICE:
4356 arvif->vdev_type = WMI_VDEV_TYPE_STA;
4357 arvif->vdev_subtype = WMI_VDEV_SUBTYPE_P2P_DEVICE;
4358 break;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004359 case NL80211_IFTYPE_UNSPECIFIED:
4360 case NL80211_IFTYPE_STATION:
4361 arvif->vdev_type = WMI_VDEV_TYPE_STA;
4362 if (vif->p2p)
4363 arvif->vdev_subtype = WMI_VDEV_SUBTYPE_P2P_CLIENT;
4364 break;
4365 case NL80211_IFTYPE_ADHOC:
4366 arvif->vdev_type = WMI_VDEV_TYPE_IBSS;
4367 break;
Bob Copelandb6c7baf2015-09-09 12:47:36 -04004368 case NL80211_IFTYPE_MESH_POINT:
Peter Ohbb58b892015-11-24 09:37:35 -08004369 if (test_bit(WMI_SERVICE_MESH, ar->wmi.svc_map)) {
4370 arvif->vdev_subtype = WMI_VDEV_SUBTYPE_MESH;
4371 } else if (!test_bit(ATH10K_FLAG_RAW_MODE, &ar->dev_flags)) {
Bob Copelandb6c7baf2015-09-09 12:47:36 -04004372 ret = -EINVAL;
4373 ath10k_warn(ar, "must load driver with rawmode=1 to add mesh interfaces\n");
4374 goto err;
4375 }
4376 arvif->vdev_type = WMI_VDEV_TYPE_AP;
4377 break;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004378 case NL80211_IFTYPE_AP:
4379 arvif->vdev_type = WMI_VDEV_TYPE_AP;
4380
4381 if (vif->p2p)
4382 arvif->vdev_subtype = WMI_VDEV_SUBTYPE_P2P_GO;
4383 break;
4384 case NL80211_IFTYPE_MONITOR:
4385 arvif->vdev_type = WMI_VDEV_TYPE_MONITOR;
4386 break;
4387 default:
4388 WARN_ON(1);
4389 break;
4390 }
4391
Michal Kazior96d828d2015-03-31 10:26:23 +00004392 /* Using vdev_id as queue number will make it very easy to do per-vif
4393 * tx queue locking. This shouldn't wrap due to interface combinations
4394 * but do a modulo for correctness sake and prevent using offchannel tx
4395 * queues for regular vif tx.
4396 */
4397 vif->cab_queue = arvif->vdev_id % (IEEE80211_MAX_QUEUES - 1);
4398 for (i = 0; i < ARRAY_SIZE(vif->hw_queue); i++)
4399 vif->hw_queue[i] = arvif->vdev_id % (IEEE80211_MAX_QUEUES - 1);
4400
Michal Kazior64badcb2014-09-18 11:18:02 +03004401 /* Some firmware revisions don't wait for beacon tx completion before
4402 * sending another SWBA event. This could lead to hardware using old
4403 * (freed) beacon data in some cases, e.g. tx credit starvation
4404 * combined with missed TBTT. This is very very rare.
4405 *
4406 * On non-IOMMU-enabled hosts this could be a possible security issue
4407 * because hw could beacon some random data on the air. On
4408 * IOMMU-enabled hosts DMAR faults would occur in most cases and target
4409 * device would crash.
4410 *
4411 * Since there are no beacon tx completions (implicit nor explicit)
4412 * propagated to host the only workaround for this is to allocate a
4413 * DMA-coherent buffer for a lifetime of a vif and use it for all
4414 * beacon tx commands. Worst case for this approach is some beacons may
4415 * become corrupted, e.g. have garbled IEs or out-of-date TIM bitmap.
4416 */
4417 if (vif->type == NL80211_IFTYPE_ADHOC ||
Bob Copelandb6c7baf2015-09-09 12:47:36 -04004418 vif->type == NL80211_IFTYPE_MESH_POINT ||
Michal Kazior64badcb2014-09-18 11:18:02 +03004419 vif->type == NL80211_IFTYPE_AP) {
4420 arvif->beacon_buf = dma_zalloc_coherent(ar->dev,
4421 IEEE80211_MAX_FRAME_LEN,
4422 &arvif->beacon_paddr,
Rajkumar Manoharan82d7aba2014-10-10 17:38:27 +05304423 GFP_ATOMIC);
Michal Kazior64badcb2014-09-18 11:18:02 +03004424 if (!arvif->beacon_buf) {
4425 ret = -ENOMEM;
4426 ath10k_warn(ar, "failed to allocate beacon buffer: %d\n",
4427 ret);
4428 goto err;
4429 }
4430 }
David Liuccec9032015-07-24 20:25:32 +03004431 if (test_bit(ATH10K_FLAG_HW_CRYPTO_DISABLED, &ar->dev_flags))
4432 arvif->nohwcrypt = true;
4433
4434 if (arvif->nohwcrypt &&
4435 !test_bit(ATH10K_FLAG_RAW_MODE, &ar->dev_flags)) {
4436 ath10k_warn(ar, "cryptmode module param needed for sw crypto\n");
4437 goto err;
4438 }
Michal Kazior64badcb2014-09-18 11:18:02 +03004439
4440 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev create %d (add interface) type %d subtype %d bcnmode %s\n",
4441 arvif->vdev_id, arvif->vdev_type, arvif->vdev_subtype,
4442 arvif->beacon_buf ? "single-buf" : "per-skb");
Kalle Valo5e3dd152013-06-12 20:52:10 +03004443
4444 ret = ath10k_wmi_vdev_create(ar, arvif->vdev_id, arvif->vdev_type,
4445 arvif->vdev_subtype, vif->addr);
4446 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004447 ath10k_warn(ar, "failed to create WMI vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004448 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004449 goto err;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004450 }
4451
Ben Greear16c11172014-09-23 14:17:16 -07004452 ar->free_vdev_map &= ~(1LL << arvif->vdev_id);
Michal Kazior05791192013-10-16 15:44:45 +03004453 list_add(&arvif->list, &ar->arvifs);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004454
Michal Kazior46725b152015-01-28 09:57:49 +02004455 /* It makes no sense to have firmware do keepalives. mac80211 already
4456 * takes care of this with idle connection polling.
4457 */
4458 ret = ath10k_mac_vif_disable_keepalive(arvif);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004459 if (ret) {
Michal Kazior46725b152015-01-28 09:57:49 +02004460 ath10k_warn(ar, "failed to disable keepalive on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004461 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004462 goto err_vdev_delete;
4463 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004464
SenthilKumar Jegadeesan627613f2015-01-29 13:50:38 +02004465 arvif->def_wep_key_idx = -1;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004466
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02004467 vdev_param = ar->wmi.vdev_param->tx_encap_type;
4468 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03004469 ATH10K_HW_TXRX_NATIVE_WIFI);
Bartosz Markowskiebc9abd2013-10-15 09:26:20 +02004470 /* 10.X firmware does not support this VDEV parameter. Do not warn */
Michal Kazior9dad14a2013-10-16 15:44:45 +03004471 if (ret && ret != -EOPNOTSUPP) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004472 ath10k_warn(ar, "failed to set vdev %i TX encapsulation: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004473 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004474 goto err_vdev_delete;
4475 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004476
Ben Greear5572a952014-11-24 16:22:10 +02004477 if (ar->cfg_tx_chainmask) {
4478 u16 nss = get_nss_from_chainmask(ar->cfg_tx_chainmask);
4479
4480 vdev_param = ar->wmi.vdev_param->nss;
4481 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
4482 nss);
4483 if (ret) {
4484 ath10k_warn(ar, "failed to set vdev %i chainmask 0x%x, nss %i: %d\n",
4485 arvif->vdev_id, ar->cfg_tx_chainmask, nss,
4486 ret);
4487 goto err_vdev_delete;
4488 }
4489 }
4490
Michal Kaziore57e0572015-03-24 13:14:03 +00004491 if (arvif->vdev_type == WMI_VDEV_TYPE_AP ||
4492 arvif->vdev_type == WMI_VDEV_TYPE_IBSS) {
Marek Puzyniak7390ed32015-03-30 09:51:52 +03004493 ret = ath10k_peer_create(ar, arvif->vdev_id, vif->addr,
4494 WMI_PEER_TYPE_DEFAULT);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004495 if (ret) {
Michal Kaziore57e0572015-03-24 13:14:03 +00004496 ath10k_warn(ar, "failed to create vdev %i peer for AP/IBSS: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004497 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004498 goto err_vdev_delete;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004499 }
Michal Kaziore57e0572015-03-24 13:14:03 +00004500 }
Marek Puzyniakcdf07402013-12-30 09:07:51 +01004501
Michal Kaziore57e0572015-03-24 13:14:03 +00004502 if (arvif->vdev_type == WMI_VDEV_TYPE_AP) {
Kalle Valo5a13e762014-01-20 11:01:46 +02004503 ret = ath10k_mac_set_kickout(arvif);
4504 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004505 ath10k_warn(ar, "failed to set vdev %i kickout parameters: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004506 arvif->vdev_id, ret);
Kalle Valo5a13e762014-01-20 11:01:46 +02004507 goto err_peer_delete;
4508 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004509 }
4510
4511 if (arvif->vdev_type == WMI_VDEV_TYPE_STA) {
4512 param = WMI_STA_PS_PARAM_RX_WAKE_POLICY;
4513 value = WMI_STA_PS_RX_WAKE_POLICY_WAKE;
4514 ret = ath10k_wmi_set_sta_ps_param(ar, arvif->vdev_id,
4515 param, value);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004516 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004517 ath10k_warn(ar, "failed to set vdev %i RX wake policy: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004518 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004519 goto err_peer_delete;
4520 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004521
Michal Kazior9f9b5742014-12-12 12:41:36 +01004522 ret = ath10k_mac_vif_recalc_ps_wake_threshold(arvif);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004523 if (ret) {
Michal Kazior9f9b5742014-12-12 12:41:36 +01004524 ath10k_warn(ar, "failed to recalc ps wake threshold on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004525 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004526 goto err_peer_delete;
4527 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004528
Michal Kazior9f9b5742014-12-12 12:41:36 +01004529 ret = ath10k_mac_vif_recalc_ps_poll_count(arvif);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004530 if (ret) {
Michal Kazior9f9b5742014-12-12 12:41:36 +01004531 ath10k_warn(ar, "failed to recalc ps poll count on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004532 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004533 goto err_peer_delete;
4534 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004535 }
4536
Vivek Natarajana48e2cc2015-08-04 10:45:12 +05304537 ret = ath10k_mac_set_txbf_conf(arvif);
4538 if (ret) {
4539 ath10k_warn(ar, "failed to set txbf for vdev %d: %d\n",
4540 arvif->vdev_id, ret);
4541 goto err_peer_delete;
4542 }
4543
Michal Kazior424121c2013-07-22 14:13:31 +02004544 ret = ath10k_mac_set_rts(arvif, ar->hw->wiphy->rts_threshold);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004545 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004546 ath10k_warn(ar, "failed to set rts threshold for vdev %d: %d\n",
Michal Kazior679c54a2013-07-05 16:15:04 +03004547 arvif->vdev_id, ret);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004548 goto err_peer_delete;
4549 }
Michal Kazior679c54a2013-07-05 16:15:04 +03004550
Michal Kazior7d9d5582014-10-21 10:40:15 +03004551 arvif->txpower = vif->bss_conf.txpower;
4552 ret = ath10k_mac_txpower_recalc(ar);
4553 if (ret) {
4554 ath10k_warn(ar, "failed to recalc tx power: %d\n", ret);
4555 goto err_peer_delete;
4556 }
4557
Michal Kazior500ff9f2015-03-31 10:26:21 +00004558 if (vif->type == NL80211_IFTYPE_MONITOR) {
4559 ar->monitor_arvif = arvif;
4560 ret = ath10k_monitor_recalc(ar);
4561 if (ret) {
4562 ath10k_warn(ar, "failed to recalc monitor: %d\n", ret);
4563 goto err_peer_delete;
4564 }
4565 }
4566
Michal Kazior6d2d51e2015-08-07 09:08:21 +02004567 spin_lock_bh(&ar->htt.tx_lock);
4568 if (!ar->tx_paused)
4569 ieee80211_wake_queue(ar->hw, arvif->vdev_id);
4570 spin_unlock_bh(&ar->htt.tx_lock);
4571
Kalle Valo5e3dd152013-06-12 20:52:10 +03004572 mutex_unlock(&ar->conf_mutex);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004573 return 0;
4574
4575err_peer_delete:
Michal Kaziore57e0572015-03-24 13:14:03 +00004576 if (arvif->vdev_type == WMI_VDEV_TYPE_AP ||
4577 arvif->vdev_type == WMI_VDEV_TYPE_IBSS)
Michal Kazior9dad14a2013-10-16 15:44:45 +03004578 ath10k_wmi_peer_delete(ar, arvif->vdev_id, vif->addr);
4579
4580err_vdev_delete:
4581 ath10k_wmi_vdev_delete(ar, arvif->vdev_id);
Ben Greear16c11172014-09-23 14:17:16 -07004582 ar->free_vdev_map |= 1LL << arvif->vdev_id;
Michal Kazior05791192013-10-16 15:44:45 +03004583 list_del(&arvif->list);
Michal Kazior9dad14a2013-10-16 15:44:45 +03004584
4585err:
Michal Kazior64badcb2014-09-18 11:18:02 +03004586 if (arvif->beacon_buf) {
4587 dma_free_coherent(ar->dev, IEEE80211_MAX_FRAME_LEN,
4588 arvif->beacon_buf, arvif->beacon_paddr);
4589 arvif->beacon_buf = NULL;
4590 }
4591
Michal Kazior9dad14a2013-10-16 15:44:45 +03004592 mutex_unlock(&ar->conf_mutex);
4593
Kalle Valo5e3dd152013-06-12 20:52:10 +03004594 return ret;
4595}
4596
Michal Kaziorb4aa5392015-03-31 10:26:24 +00004597static void ath10k_mac_vif_tx_unlock_all(struct ath10k_vif *arvif)
4598{
4599 int i;
4600
4601 for (i = 0; i < BITS_PER_LONG; i++)
4602 ath10k_mac_vif_tx_unlock(arvif, i);
4603}
4604
Kalle Valo5e3dd152013-06-12 20:52:10 +03004605static void ath10k_remove_interface(struct ieee80211_hw *hw,
4606 struct ieee80211_vif *vif)
4607{
4608 struct ath10k *ar = hw->priv;
4609 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
4610 int ret;
4611
Michal Kazior81a9a172015-03-05 16:02:17 +02004612 cancel_work_sync(&arvif->ap_csa_work);
Michal Kaziorcc9904e2015-03-10 16:22:01 +02004613 cancel_delayed_work_sync(&arvif->connection_loss_work);
Michal Kazior81a9a172015-03-05 16:02:17 +02004614
Sujith Manoharan5d011f52014-11-25 11:47:00 +05304615 mutex_lock(&ar->conf_mutex);
4616
Michal Kaziored543882013-09-13 14:16:56 +02004617 spin_lock_bh(&ar->data_lock);
Michal Kazior64badcb2014-09-18 11:18:02 +03004618 ath10k_mac_vif_beacon_cleanup(arvif);
Michal Kaziored543882013-09-13 14:16:56 +02004619 spin_unlock_bh(&ar->data_lock);
4620
Simon Wunderlich855aed12014-08-02 09:12:54 +03004621 ret = ath10k_spectral_vif_stop(arvif);
4622 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02004623 ath10k_warn(ar, "failed to stop spectral for vdev %i: %d\n",
Simon Wunderlich855aed12014-08-02 09:12:54 +03004624 arvif->vdev_id, ret);
4625
Ben Greear16c11172014-09-23 14:17:16 -07004626 ar->free_vdev_map |= 1LL << arvif->vdev_id;
Michal Kazior05791192013-10-16 15:44:45 +03004627 list_del(&arvif->list);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004628
Michal Kaziore57e0572015-03-24 13:14:03 +00004629 if (arvif->vdev_type == WMI_VDEV_TYPE_AP ||
4630 arvif->vdev_type == WMI_VDEV_TYPE_IBSS) {
Michal Kazior2c512052015-02-15 16:50:40 +02004631 ret = ath10k_wmi_peer_delete(arvif->ar, arvif->vdev_id,
4632 vif->addr);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004633 if (ret)
Michal Kaziore57e0572015-03-24 13:14:03 +00004634 ath10k_warn(ar, "failed to submit AP/IBSS self-peer removal on vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004635 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004636
4637 kfree(arvif->u.ap.noa_data);
4638 }
4639
Michal Kazior7aa7a722014-08-25 12:09:38 +02004640 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %i delete (remove interface)\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03004641 arvif->vdev_id);
4642
Kalle Valo5e3dd152013-06-12 20:52:10 +03004643 ret = ath10k_wmi_vdev_delete(ar, arvif->vdev_id);
4644 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02004645 ath10k_warn(ar, "failed to delete WMI vdev %i: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004646 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004647
Michal Kazior2c512052015-02-15 16:50:40 +02004648 /* Some firmware revisions don't notify host about self-peer removal
4649 * until after associated vdev is deleted.
4650 */
Michal Kaziore57e0572015-03-24 13:14:03 +00004651 if (arvif->vdev_type == WMI_VDEV_TYPE_AP ||
4652 arvif->vdev_type == WMI_VDEV_TYPE_IBSS) {
Michal Kazior2c512052015-02-15 16:50:40 +02004653 ret = ath10k_wait_for_peer_deleted(ar, arvif->vdev_id,
4654 vif->addr);
4655 if (ret)
4656 ath10k_warn(ar, "failed to remove AP self-peer on vdev %i: %d\n",
4657 arvif->vdev_id, ret);
4658
4659 spin_lock_bh(&ar->data_lock);
4660 ar->num_peers--;
4661 spin_unlock_bh(&ar->data_lock);
4662 }
4663
Kalle Valo5e3dd152013-06-12 20:52:10 +03004664 ath10k_peer_cleanup(ar, arvif->vdev_id);
4665
Michal Kazior500ff9f2015-03-31 10:26:21 +00004666 if (vif->type == NL80211_IFTYPE_MONITOR) {
4667 ar->monitor_arvif = NULL;
4668 ret = ath10k_monitor_recalc(ar);
4669 if (ret)
4670 ath10k_warn(ar, "failed to recalc monitor: %d\n", ret);
4671 }
4672
Michal Kaziorb4aa5392015-03-31 10:26:24 +00004673 spin_lock_bh(&ar->htt.tx_lock);
4674 ath10k_mac_vif_tx_unlock_all(arvif);
4675 spin_unlock_bh(&ar->htt.tx_lock);
4676
Kalle Valo5e3dd152013-06-12 20:52:10 +03004677 mutex_unlock(&ar->conf_mutex);
4678}
4679
4680/*
4681 * FIXME: Has to be verified.
4682 */
4683#define SUPPORTED_FILTERS \
Johannes Bergdf140462015-04-22 14:40:58 +02004684 (FIF_ALLMULTI | \
Kalle Valo5e3dd152013-06-12 20:52:10 +03004685 FIF_CONTROL | \
4686 FIF_PSPOLL | \
4687 FIF_OTHER_BSS | \
4688 FIF_BCN_PRBRESP_PROMISC | \
4689 FIF_PROBE_REQ | \
4690 FIF_FCSFAIL)
4691
4692static void ath10k_configure_filter(struct ieee80211_hw *hw,
4693 unsigned int changed_flags,
4694 unsigned int *total_flags,
4695 u64 multicast)
4696{
4697 struct ath10k *ar = hw->priv;
4698 int ret;
4699
4700 mutex_lock(&ar->conf_mutex);
4701
4702 changed_flags &= SUPPORTED_FILTERS;
4703 *total_flags &= SUPPORTED_FILTERS;
4704 ar->filter_flags = *total_flags;
4705
Michal Kazior19337472014-08-28 12:58:16 +02004706 ret = ath10k_monitor_recalc(ar);
4707 if (ret)
4708 ath10k_warn(ar, "failed to recalc montior: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004709
4710 mutex_unlock(&ar->conf_mutex);
4711}
4712
4713static void ath10k_bss_info_changed(struct ieee80211_hw *hw,
4714 struct ieee80211_vif *vif,
4715 struct ieee80211_bss_conf *info,
4716 u32 changed)
4717{
4718 struct ath10k *ar = hw->priv;
4719 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
4720 int ret = 0;
Kalle Valoaf762c02014-09-14 12:50:17 +03004721 u32 vdev_param, pdev_param, slottime, preamble;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004722
4723 mutex_lock(&ar->conf_mutex);
4724
4725 if (changed & BSS_CHANGED_IBSS)
4726 ath10k_control_ibss(arvif, info, vif->addr);
4727
4728 if (changed & BSS_CHANGED_BEACON_INT) {
4729 arvif->beacon_interval = info->beacon_int;
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02004730 vdev_param = ar->wmi.vdev_param->beacon_interval;
4731 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03004732 arvif->beacon_interval);
Michal Kazior7aa7a722014-08-25 12:09:38 +02004733 ath10k_dbg(ar, ATH10K_DBG_MAC,
Kalle Valo60c3daa2013-09-08 17:56:07 +03004734 "mac vdev %d beacon_interval %d\n",
4735 arvif->vdev_id, arvif->beacon_interval);
4736
Kalle Valo5e3dd152013-06-12 20:52:10 +03004737 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02004738 ath10k_warn(ar, "failed to set beacon interval for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02004739 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004740 }
4741
4742 if (changed & BSS_CHANGED_BEACON) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004743 ath10k_dbg(ar, ATH10K_DBG_MAC,
Kalle Valo60c3daa2013-09-08 17:56:07 +03004744 "vdev %d set beacon tx mode to staggered\n",
4745 arvif->vdev_id);
4746
Bartosz Markowski226a3392013-09-26 17:47:16 +02004747 pdev_param = ar->wmi.pdev_param->beacon_tx_mode;
4748 ret = ath10k_wmi_pdev_set_param(ar, pdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03004749 WMI_BEACON_STAGGERED_MODE);
4750 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02004751 ath10k_warn(ar, "failed to set beacon mode for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02004752 arvif->vdev_id, ret);
Michal Kaziorfbb8f1b2015-01-13 16:30:12 +02004753
4754 ret = ath10k_mac_setup_bcn_tmpl(arvif);
4755 if (ret)
4756 ath10k_warn(ar, "failed to update beacon template: %d\n",
4757 ret);
Bob Copelandb6c7baf2015-09-09 12:47:36 -04004758
4759 if (ieee80211_vif_is_mesh(vif)) {
4760 /* mesh doesn't use SSID but firmware needs it */
4761 strncpy(arvif->u.ap.ssid, "mesh",
4762 sizeof(arvif->u.ap.ssid));
4763 arvif->u.ap.ssid_len = 4;
4764 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004765 }
4766
Michal Kaziorfbb8f1b2015-01-13 16:30:12 +02004767 if (changed & BSS_CHANGED_AP_PROBE_RESP) {
4768 ret = ath10k_mac_setup_prb_tmpl(arvif);
4769 if (ret)
4770 ath10k_warn(ar, "failed to setup probe resp template on vdev %i: %d\n",
4771 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004772 }
4773
Michal Kaziorba2479f2015-01-24 12:14:51 +02004774 if (changed & (BSS_CHANGED_BEACON_INFO | BSS_CHANGED_BEACON)) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03004775 arvif->dtim_period = info->dtim_period;
4776
Michal Kazior7aa7a722014-08-25 12:09:38 +02004777 ath10k_dbg(ar, ATH10K_DBG_MAC,
Kalle Valo60c3daa2013-09-08 17:56:07 +03004778 "mac vdev %d dtim_period %d\n",
4779 arvif->vdev_id, arvif->dtim_period);
4780
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02004781 vdev_param = ar->wmi.vdev_param->dtim_period;
4782 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03004783 arvif->dtim_period);
4784 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02004785 ath10k_warn(ar, "failed to set dtim period for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02004786 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004787 }
4788
4789 if (changed & BSS_CHANGED_SSID &&
4790 vif->type == NL80211_IFTYPE_AP) {
4791 arvif->u.ap.ssid_len = info->ssid_len;
4792 if (info->ssid_len)
4793 memcpy(arvif->u.ap.ssid, info->ssid, info->ssid_len);
4794 arvif->u.ap.hidden_ssid = info->hidden_ssid;
4795 }
4796
Michal Kazior077efc82014-10-21 10:10:29 +03004797 if (changed & BSS_CHANGED_BSSID && !is_zero_ether_addr(info->bssid))
4798 ether_addr_copy(arvif->bssid, info->bssid);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004799
4800 if (changed & BSS_CHANGED_BEACON_ENABLED)
4801 ath10k_control_beaconing(arvif, info);
4802
4803 if (changed & BSS_CHANGED_ERP_CTS_PROT) {
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02004804 arvif->use_cts_prot = info->use_cts_prot;
Michal Kazior7aa7a722014-08-25 12:09:38 +02004805 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %d cts_prot %d\n",
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02004806 arvif->vdev_id, info->use_cts_prot);
Kalle Valo60c3daa2013-09-08 17:56:07 +03004807
Marek Kwaczynskie81bd102014-03-11 12:58:00 +02004808 ret = ath10k_recalc_rtscts_prot(arvif);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004809 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02004810 ath10k_warn(ar, "failed to recalculate rts/cts prot for vdev %d: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02004811 arvif->vdev_id, ret);
Michal Kaziora87fd4b2015-03-02 11:21:17 +01004812
4813 vdev_param = ar->wmi.vdev_param->protection_mode;
4814 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
4815 info->use_cts_prot ? 1 : 0);
4816 if (ret)
4817 ath10k_warn(ar, "failed to set protection mode %d on vdev %i: %d\n",
Kalle Valo617b0f42015-10-05 17:56:35 +03004818 info->use_cts_prot, arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004819 }
4820
4821 if (changed & BSS_CHANGED_ERP_SLOT) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03004822 if (info->use_short_slot)
4823 slottime = WMI_VDEV_SLOT_TIME_SHORT; /* 9us */
4824
4825 else
4826 slottime = WMI_VDEV_SLOT_TIME_LONG; /* 20us */
4827
Michal Kazior7aa7a722014-08-25 12:09:38 +02004828 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %d slot_time %d\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03004829 arvif->vdev_id, slottime);
4830
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02004831 vdev_param = ar->wmi.vdev_param->slot_time;
4832 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03004833 slottime);
4834 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02004835 ath10k_warn(ar, "failed to set erp slot for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02004836 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004837 }
4838
4839 if (changed & BSS_CHANGED_ERP_PREAMBLE) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03004840 if (info->use_short_preamble)
4841 preamble = WMI_VDEV_PREAMBLE_SHORT;
4842 else
4843 preamble = WMI_VDEV_PREAMBLE_LONG;
4844
Michal Kazior7aa7a722014-08-25 12:09:38 +02004845 ath10k_dbg(ar, ATH10K_DBG_MAC,
Kalle Valo60c3daa2013-09-08 17:56:07 +03004846 "mac vdev %d preamble %dn",
4847 arvif->vdev_id, preamble);
4848
Bartosz Markowski6d1506e2013-09-26 17:47:15 +02004849 vdev_param = ar->wmi.vdev_param->preamble;
4850 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
Kalle Valo5e3dd152013-06-12 20:52:10 +03004851 preamble);
4852 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02004853 ath10k_warn(ar, "failed to set preamble for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02004854 arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004855 }
4856
4857 if (changed & BSS_CHANGED_ASSOC) {
Michal Kaziore556f112014-08-28 12:58:17 +02004858 if (info->assoc) {
4859 /* Workaround: Make sure monitor vdev is not running
4860 * when associating to prevent some firmware revisions
4861 * (e.g. 10.1 and 10.2) from crashing.
4862 */
4863 if (ar->monitor_started)
4864 ath10k_monitor_stop(ar);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004865 ath10k_bss_assoc(hw, vif, info);
Michal Kaziore556f112014-08-28 12:58:17 +02004866 ath10k_monitor_recalc(ar);
Michal Kazior077efc82014-10-21 10:10:29 +03004867 } else {
4868 ath10k_bss_disassoc(hw, vif);
Michal Kaziore556f112014-08-28 12:58:17 +02004869 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004870 }
4871
Michal Kazior7d9d5582014-10-21 10:40:15 +03004872 if (changed & BSS_CHANGED_TXPOWER) {
4873 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev_id %i txpower %d\n",
4874 arvif->vdev_id, info->txpower);
4875
4876 arvif->txpower = info->txpower;
4877 ret = ath10k_mac_txpower_recalc(ar);
4878 if (ret)
4879 ath10k_warn(ar, "failed to recalc tx power: %d\n", ret);
4880 }
4881
Michal Kaziorbf14e652014-12-12 12:41:38 +01004882 if (changed & BSS_CHANGED_PS) {
Michal Kaziorcffb41f2015-02-13 13:30:16 +01004883 arvif->ps = vif->bss_conf.ps;
4884
4885 ret = ath10k_config_ps(ar);
Michal Kaziorbf14e652014-12-12 12:41:38 +01004886 if (ret)
4887 ath10k_warn(ar, "failed to setup ps on vdev %i: %d\n",
4888 arvif->vdev_id, ret);
4889 }
4890
Kalle Valo5e3dd152013-06-12 20:52:10 +03004891 mutex_unlock(&ar->conf_mutex);
4892}
4893
4894static int ath10k_hw_scan(struct ieee80211_hw *hw,
4895 struct ieee80211_vif *vif,
David Spinadelc56ef672014-02-05 15:21:13 +02004896 struct ieee80211_scan_request *hw_req)
Kalle Valo5e3dd152013-06-12 20:52:10 +03004897{
4898 struct ath10k *ar = hw->priv;
4899 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
David Spinadelc56ef672014-02-05 15:21:13 +02004900 struct cfg80211_scan_request *req = &hw_req->req;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004901 struct wmi_start_scan_arg arg;
4902 int ret = 0;
4903 int i;
4904
4905 mutex_lock(&ar->conf_mutex);
4906
4907 spin_lock_bh(&ar->data_lock);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02004908 switch (ar->scan.state) {
4909 case ATH10K_SCAN_IDLE:
4910 reinit_completion(&ar->scan.started);
4911 reinit_completion(&ar->scan.completed);
4912 ar->scan.state = ATH10K_SCAN_STARTING;
4913 ar->scan.is_roc = false;
4914 ar->scan.vdev_id = arvif->vdev_id;
4915 ret = 0;
4916 break;
4917 case ATH10K_SCAN_STARTING:
4918 case ATH10K_SCAN_RUNNING:
4919 case ATH10K_SCAN_ABORTING:
Kalle Valo5e3dd152013-06-12 20:52:10 +03004920 ret = -EBUSY;
Michal Kazior5c81c7f2014-08-05 14:54:44 +02004921 break;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004922 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03004923 spin_unlock_bh(&ar->data_lock);
4924
Michal Kazior5c81c7f2014-08-05 14:54:44 +02004925 if (ret)
4926 goto exit;
4927
Kalle Valo5e3dd152013-06-12 20:52:10 +03004928 memset(&arg, 0, sizeof(arg));
4929 ath10k_wmi_start_scan_init(ar, &arg);
4930 arg.vdev_id = arvif->vdev_id;
4931 arg.scan_id = ATH10K_SCAN_ID;
4932
Kalle Valo5e3dd152013-06-12 20:52:10 +03004933 if (req->ie_len) {
4934 arg.ie_len = req->ie_len;
4935 memcpy(arg.ie, req->ie, arg.ie_len);
4936 }
4937
4938 if (req->n_ssids) {
4939 arg.n_ssids = req->n_ssids;
4940 for (i = 0; i < arg.n_ssids; i++) {
4941 arg.ssids[i].len = req->ssids[i].ssid_len;
4942 arg.ssids[i].ssid = req->ssids[i].ssid;
4943 }
Michal Kaziordcd4a562013-07-31 10:55:12 +02004944 } else {
4945 arg.scan_ctrl_flags |= WMI_SCAN_FLAG_PASSIVE;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004946 }
4947
4948 if (req->n_channels) {
4949 arg.n_channels = req->n_channels;
4950 for (i = 0; i < arg.n_channels; i++)
4951 arg.channels[i] = req->channels[i]->center_freq;
4952 }
4953
4954 ret = ath10k_start_scan(ar, &arg);
4955 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02004956 ath10k_warn(ar, "failed to start hw scan: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004957 spin_lock_bh(&ar->data_lock);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02004958 ar->scan.state = ATH10K_SCAN_IDLE;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004959 spin_unlock_bh(&ar->data_lock);
4960 }
4961
Michal Kazior634349b2015-09-03 10:43:45 +02004962 /* Add a 200ms margin to account for event/command processing */
4963 ieee80211_queue_delayed_work(ar->hw, &ar->scan.timeout,
4964 msecs_to_jiffies(arg.max_scan_time +
4965 200));
4966
Kalle Valo5e3dd152013-06-12 20:52:10 +03004967exit:
4968 mutex_unlock(&ar->conf_mutex);
4969 return ret;
4970}
4971
4972static void ath10k_cancel_hw_scan(struct ieee80211_hw *hw,
4973 struct ieee80211_vif *vif)
4974{
4975 struct ath10k *ar = hw->priv;
Kalle Valo5e3dd152013-06-12 20:52:10 +03004976
4977 mutex_lock(&ar->conf_mutex);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02004978 ath10k_scan_abort(ar);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004979 mutex_unlock(&ar->conf_mutex);
Michal Kazior4eb2e162014-10-28 10:23:09 +01004980
4981 cancel_delayed_work_sync(&ar->scan.timeout);
Kalle Valo5e3dd152013-06-12 20:52:10 +03004982}
4983
Michal Kaziorcfb27d22013-12-02 09:06:36 +01004984static void ath10k_set_key_h_def_keyidx(struct ath10k *ar,
4985 struct ath10k_vif *arvif,
4986 enum set_key_cmd cmd,
4987 struct ieee80211_key_conf *key)
4988{
4989 u32 vdev_param = arvif->ar->wmi.vdev_param->def_keyid;
4990 int ret;
4991
4992 /* 10.1 firmware branch requires default key index to be set to group
4993 * key index after installing it. Otherwise FW/HW Txes corrupted
4994 * frames with multi-vif APs. This is not required for main firmware
4995 * branch (e.g. 636).
4996 *
Michal Kazior8461baf2015-04-10 13:23:22 +00004997 * This is also needed for 636 fw for IBSS-RSN to work more reliably.
4998 *
4999 * FIXME: It remains unknown if this is required for multi-vif STA
5000 * interfaces on 10.1.
5001 */
Michal Kaziorcfb27d22013-12-02 09:06:36 +01005002
Michal Kazior8461baf2015-04-10 13:23:22 +00005003 if (arvif->vdev_type != WMI_VDEV_TYPE_AP &&
5004 arvif->vdev_type != WMI_VDEV_TYPE_IBSS)
Michal Kaziorcfb27d22013-12-02 09:06:36 +01005005 return;
5006
5007 if (key->cipher == WLAN_CIPHER_SUITE_WEP40)
5008 return;
5009
5010 if (key->cipher == WLAN_CIPHER_SUITE_WEP104)
5011 return;
5012
5013 if (key->flags & IEEE80211_KEY_FLAG_PAIRWISE)
5014 return;
5015
5016 if (cmd != SET_KEY)
5017 return;
5018
5019 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param,
5020 key->keyidx);
5021 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005022 ath10k_warn(ar, "failed to set vdev %i group key as default key: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02005023 arvif->vdev_id, ret);
Michal Kaziorcfb27d22013-12-02 09:06:36 +01005024}
5025
Kalle Valo5e3dd152013-06-12 20:52:10 +03005026static int ath10k_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd,
5027 struct ieee80211_vif *vif, struct ieee80211_sta *sta,
5028 struct ieee80211_key_conf *key)
5029{
5030 struct ath10k *ar = hw->priv;
5031 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
5032 struct ath10k_peer *peer;
5033 const u8 *peer_addr;
5034 bool is_wep = key->cipher == WLAN_CIPHER_SUITE_WEP40 ||
5035 key->cipher == WLAN_CIPHER_SUITE_WEP104;
5036 int ret = 0;
Michal Kazior29a10002015-04-10 13:05:58 +00005037 int ret2;
Michal Kazior370e5672015-02-18 14:02:26 +01005038 u32 flags = 0;
Michal Kazior29a10002015-04-10 13:05:58 +00005039 u32 flags2;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005040
Bartosz Markowskid7131c02015-03-10 14:32:19 +01005041 /* this one needs to be done in software */
5042 if (key->cipher == WLAN_CIPHER_SUITE_AES_CMAC)
5043 return 1;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005044
David Liuccec9032015-07-24 20:25:32 +03005045 if (arvif->nohwcrypt)
5046 return 1;
5047
Kalle Valo5e3dd152013-06-12 20:52:10 +03005048 if (key->keyidx > WMI_MAX_KEY_INDEX)
5049 return -ENOSPC;
5050
5051 mutex_lock(&ar->conf_mutex);
5052
5053 if (sta)
5054 peer_addr = sta->addr;
5055 else if (arvif->vdev_type == WMI_VDEV_TYPE_STA)
5056 peer_addr = vif->bss_conf.bssid;
5057 else
5058 peer_addr = vif->addr;
5059
5060 key->hw_key_idx = key->keyidx;
5061
Michal Kazior7c8cc7e2015-04-01 22:53:19 +03005062 if (is_wep) {
5063 if (cmd == SET_KEY)
5064 arvif->wep_keys[key->keyidx] = key;
5065 else
5066 arvif->wep_keys[key->keyidx] = NULL;
5067 }
5068
Kalle Valo5e3dd152013-06-12 20:52:10 +03005069 /* the peer should not disappear in mid-way (unless FW goes awry) since
5070 * we already hold conf_mutex. we just make sure its there now. */
5071 spin_lock_bh(&ar->data_lock);
5072 peer = ath10k_peer_find(ar, arvif->vdev_id, peer_addr);
5073 spin_unlock_bh(&ar->data_lock);
5074
5075 if (!peer) {
5076 if (cmd == SET_KEY) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005077 ath10k_warn(ar, "failed to install key for non-existent peer %pM\n",
Kalle Valo5e3dd152013-06-12 20:52:10 +03005078 peer_addr);
5079 ret = -EOPNOTSUPP;
5080 goto exit;
5081 } else {
5082 /* if the peer doesn't exist there is no key to disable
5083 * anymore */
5084 goto exit;
5085 }
5086 }
5087
Michal Kazior7cc45732015-03-09 14:24:17 +01005088 if (key->flags & IEEE80211_KEY_FLAG_PAIRWISE)
5089 flags |= WMI_KEY_PAIRWISE;
5090 else
5091 flags |= WMI_KEY_GROUP;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005092
Kalle Valo5e3dd152013-06-12 20:52:10 +03005093 if (is_wep) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03005094 if (cmd == DISABLE_KEY)
5095 ath10k_clear_vdev_key(arvif, key);
Michal Kazior370e5672015-02-18 14:02:26 +01005096
Michal Kaziorad325cb2015-02-18 14:02:27 +01005097 /* When WEP keys are uploaded it's possible that there are
5098 * stations associated already (e.g. when merging) without any
5099 * keys. Static WEP needs an explicit per-peer key upload.
5100 */
5101 if (vif->type == NL80211_IFTYPE_ADHOC &&
5102 cmd == SET_KEY)
5103 ath10k_mac_vif_update_wep_key(arvif, key);
5104
Michal Kazior370e5672015-02-18 14:02:26 +01005105 /* 802.1x never sets the def_wep_key_idx so each set_key()
5106 * call changes default tx key.
5107 *
5108 * Static WEP sets def_wep_key_idx via .set_default_unicast_key
5109 * after first set_key().
5110 */
5111 if (cmd == SET_KEY && arvif->def_wep_key_idx == -1)
5112 flags |= WMI_KEY_TX_USAGE;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005113 }
5114
Michal Kazior370e5672015-02-18 14:02:26 +01005115 ret = ath10k_install_key(arvif, key, cmd, peer_addr, flags);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005116 if (ret) {
David Liuccec9032015-07-24 20:25:32 +03005117 WARN_ON(ret > 0);
Michal Kazior7aa7a722014-08-25 12:09:38 +02005118 ath10k_warn(ar, "failed to install key for vdev %i peer %pM: %d\n",
Ben Greear69244e52014-02-27 18:50:00 +02005119 arvif->vdev_id, peer_addr, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005120 goto exit;
5121 }
5122
Michal Kazior29a10002015-04-10 13:05:58 +00005123 /* mac80211 sets static WEP keys as groupwise while firmware requires
5124 * them to be installed twice as both pairwise and groupwise.
5125 */
5126 if (is_wep && !sta && vif->type == NL80211_IFTYPE_STATION) {
5127 flags2 = flags;
5128 flags2 &= ~WMI_KEY_GROUP;
5129 flags2 |= WMI_KEY_PAIRWISE;
5130
5131 ret = ath10k_install_key(arvif, key, cmd, peer_addr, flags2);
5132 if (ret) {
David Liuccec9032015-07-24 20:25:32 +03005133 WARN_ON(ret > 0);
Michal Kazior29a10002015-04-10 13:05:58 +00005134 ath10k_warn(ar, "failed to install (ucast) key for vdev %i peer %pM: %d\n",
5135 arvif->vdev_id, peer_addr, ret);
5136 ret2 = ath10k_install_key(arvif, key, DISABLE_KEY,
5137 peer_addr, flags);
David Liuccec9032015-07-24 20:25:32 +03005138 if (ret2) {
5139 WARN_ON(ret2 > 0);
Michal Kazior29a10002015-04-10 13:05:58 +00005140 ath10k_warn(ar, "failed to disable (mcast) key for vdev %i peer %pM: %d\n",
5141 arvif->vdev_id, peer_addr, ret2);
David Liuccec9032015-07-24 20:25:32 +03005142 }
Michal Kazior29a10002015-04-10 13:05:58 +00005143 goto exit;
5144 }
5145 }
5146
Michal Kaziorcfb27d22013-12-02 09:06:36 +01005147 ath10k_set_key_h_def_keyidx(ar, arvif, cmd, key);
5148
Kalle Valo5e3dd152013-06-12 20:52:10 +03005149 spin_lock_bh(&ar->data_lock);
5150 peer = ath10k_peer_find(ar, arvif->vdev_id, peer_addr);
5151 if (peer && cmd == SET_KEY)
5152 peer->keys[key->keyidx] = key;
5153 else if (peer && cmd == DISABLE_KEY)
5154 peer->keys[key->keyidx] = NULL;
5155 else if (peer == NULL)
5156 /* impossible unless FW goes crazy */
Michal Kazior7aa7a722014-08-25 12:09:38 +02005157 ath10k_warn(ar, "Peer %pM disappeared!\n", peer_addr);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005158 spin_unlock_bh(&ar->data_lock);
5159
5160exit:
5161 mutex_unlock(&ar->conf_mutex);
5162 return ret;
5163}
5164
SenthilKumar Jegadeesan627613f2015-01-29 13:50:38 +02005165static void ath10k_set_default_unicast_key(struct ieee80211_hw *hw,
5166 struct ieee80211_vif *vif,
5167 int keyidx)
5168{
5169 struct ath10k *ar = hw->priv;
5170 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
5171 int ret;
5172
5173 mutex_lock(&arvif->ar->conf_mutex);
5174
5175 if (arvif->ar->state != ATH10K_STATE_ON)
5176 goto unlock;
5177
5178 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %d set keyidx %d\n",
5179 arvif->vdev_id, keyidx);
5180
5181 ret = ath10k_wmi_vdev_set_param(arvif->ar,
5182 arvif->vdev_id,
5183 arvif->ar->wmi.vdev_param->def_keyid,
5184 keyidx);
5185
5186 if (ret) {
5187 ath10k_warn(ar, "failed to update wep key index for vdev %d: %d\n",
5188 arvif->vdev_id,
5189 ret);
5190 goto unlock;
5191 }
5192
5193 arvif->def_wep_key_idx = keyidx;
Michal Kazior370e5672015-02-18 14:02:26 +01005194
SenthilKumar Jegadeesan627613f2015-01-29 13:50:38 +02005195unlock:
5196 mutex_unlock(&arvif->ar->conf_mutex);
5197}
5198
Michal Kazior9797feb2014-02-14 14:49:48 +01005199static void ath10k_sta_rc_update_wk(struct work_struct *wk)
5200{
5201 struct ath10k *ar;
5202 struct ath10k_vif *arvif;
5203 struct ath10k_sta *arsta;
5204 struct ieee80211_sta *sta;
Michal Kazior45c9abc2015-04-21 20:42:58 +03005205 struct cfg80211_chan_def def;
5206 enum ieee80211_band band;
5207 const u8 *ht_mcs_mask;
5208 const u16 *vht_mcs_mask;
Michal Kazior9797feb2014-02-14 14:49:48 +01005209 u32 changed, bw, nss, smps;
5210 int err;
5211
5212 arsta = container_of(wk, struct ath10k_sta, update_wk);
5213 sta = container_of((void *)arsta, struct ieee80211_sta, drv_priv);
5214 arvif = arsta->arvif;
5215 ar = arvif->ar;
5216
Michal Kazior45c9abc2015-04-21 20:42:58 +03005217 if (WARN_ON(ath10k_mac_vif_chan(arvif->vif, &def)))
5218 return;
5219
5220 band = def.chan->band;
5221 ht_mcs_mask = arvif->bitrate_mask.control[band].ht_mcs;
5222 vht_mcs_mask = arvif->bitrate_mask.control[band].vht_mcs;
5223
Michal Kazior9797feb2014-02-14 14:49:48 +01005224 spin_lock_bh(&ar->data_lock);
5225
5226 changed = arsta->changed;
5227 arsta->changed = 0;
5228
5229 bw = arsta->bw;
5230 nss = arsta->nss;
5231 smps = arsta->smps;
5232
5233 spin_unlock_bh(&ar->data_lock);
5234
5235 mutex_lock(&ar->conf_mutex);
5236
Michal Kazior45c9abc2015-04-21 20:42:58 +03005237 nss = max_t(u32, 1, nss);
5238 nss = min(nss, max(ath10k_mac_max_ht_nss(ht_mcs_mask),
5239 ath10k_mac_max_vht_nss(vht_mcs_mask)));
5240
Michal Kazior9797feb2014-02-14 14:49:48 +01005241 if (changed & IEEE80211_RC_BW_CHANGED) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005242 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac update sta %pM peer bw %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01005243 sta->addr, bw);
5244
5245 err = ath10k_wmi_peer_set_param(ar, arvif->vdev_id, sta->addr,
5246 WMI_PEER_CHAN_WIDTH, bw);
5247 if (err)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005248 ath10k_warn(ar, "failed to update STA %pM peer bw %d: %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01005249 sta->addr, bw, err);
5250 }
5251
5252 if (changed & IEEE80211_RC_NSS_CHANGED) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005253 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac update sta %pM nss %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01005254 sta->addr, nss);
5255
5256 err = ath10k_wmi_peer_set_param(ar, arvif->vdev_id, sta->addr,
5257 WMI_PEER_NSS, nss);
5258 if (err)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005259 ath10k_warn(ar, "failed to update STA %pM nss %d: %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01005260 sta->addr, nss, err);
5261 }
5262
5263 if (changed & IEEE80211_RC_SMPS_CHANGED) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005264 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac update sta %pM smps %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01005265 sta->addr, smps);
5266
5267 err = ath10k_wmi_peer_set_param(ar, arvif->vdev_id, sta->addr,
5268 WMI_PEER_SMPS_STATE, smps);
5269 if (err)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005270 ath10k_warn(ar, "failed to update STA %pM smps %d: %d\n",
Michal Kazior9797feb2014-02-14 14:49:48 +01005271 sta->addr, smps, err);
5272 }
5273
Janusz Dziedzic55884c02014-12-17 12:30:02 +02005274 if (changed & IEEE80211_RC_SUPP_RATES_CHANGED ||
5275 changed & IEEE80211_RC_NSS_CHANGED) {
5276 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac update sta %pM supp rates/nss\n",
Chun-Yeow Yeoh44d6fa92014-03-07 10:19:30 +02005277 sta->addr);
5278
Michal Kazior590922a2014-10-21 10:10:29 +03005279 err = ath10k_station_assoc(ar, arvif->vif, sta, true);
Chun-Yeow Yeoh44d6fa92014-03-07 10:19:30 +02005280 if (err)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005281 ath10k_warn(ar, "failed to reassociate station: %pM\n",
Chun-Yeow Yeoh44d6fa92014-03-07 10:19:30 +02005282 sta->addr);
5283 }
5284
Michal Kazior9797feb2014-02-14 14:49:48 +01005285 mutex_unlock(&ar->conf_mutex);
5286}
5287
Marek Puzyniak7c354242015-03-30 09:51:52 +03005288static int ath10k_mac_inc_num_stations(struct ath10k_vif *arvif,
5289 struct ieee80211_sta *sta)
Michal Kaziorcfd10612014-11-25 15:16:05 +01005290{
5291 struct ath10k *ar = arvif->ar;
5292
5293 lockdep_assert_held(&ar->conf_mutex);
5294
Marek Puzyniak7c354242015-03-30 09:51:52 +03005295 if (arvif->vdev_type == WMI_VDEV_TYPE_STA && !sta->tdls)
Michal Kaziorcfd10612014-11-25 15:16:05 +01005296 return 0;
5297
5298 if (ar->num_stations >= ar->max_num_stations)
5299 return -ENOBUFS;
5300
5301 ar->num_stations++;
5302
5303 return 0;
5304}
5305
Marek Puzyniak7c354242015-03-30 09:51:52 +03005306static void ath10k_mac_dec_num_stations(struct ath10k_vif *arvif,
5307 struct ieee80211_sta *sta)
Michal Kaziorcfd10612014-11-25 15:16:05 +01005308{
5309 struct ath10k *ar = arvif->ar;
5310
5311 lockdep_assert_held(&ar->conf_mutex);
5312
Marek Puzyniak7c354242015-03-30 09:51:52 +03005313 if (arvif->vdev_type == WMI_VDEV_TYPE_STA && !sta->tdls)
Michal Kaziorcfd10612014-11-25 15:16:05 +01005314 return;
5315
5316 ar->num_stations--;
5317}
5318
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005319struct ath10k_mac_tdls_iter_data {
5320 u32 num_tdls_stations;
5321 struct ieee80211_vif *curr_vif;
5322};
5323
5324static void ath10k_mac_tdls_vif_stations_count_iter(void *data,
5325 struct ieee80211_sta *sta)
5326{
5327 struct ath10k_mac_tdls_iter_data *iter_data = data;
5328 struct ath10k_sta *arsta = (struct ath10k_sta *)sta->drv_priv;
5329 struct ieee80211_vif *sta_vif = arsta->arvif->vif;
5330
5331 if (sta->tdls && sta_vif == iter_data->curr_vif)
5332 iter_data->num_tdls_stations++;
5333}
5334
5335static int ath10k_mac_tdls_vif_stations_count(struct ieee80211_hw *hw,
5336 struct ieee80211_vif *vif)
5337{
5338 struct ath10k_mac_tdls_iter_data data = {};
5339
5340 data.curr_vif = vif;
5341
5342 ieee80211_iterate_stations_atomic(hw,
5343 ath10k_mac_tdls_vif_stations_count_iter,
5344 &data);
5345 return data.num_tdls_stations;
5346}
5347
5348static void ath10k_mac_tdls_vifs_count_iter(void *data, u8 *mac,
5349 struct ieee80211_vif *vif)
5350{
5351 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
5352 int *num_tdls_vifs = data;
5353
5354 if (vif->type != NL80211_IFTYPE_STATION)
5355 return;
5356
5357 if (ath10k_mac_tdls_vif_stations_count(arvif->ar->hw, vif) > 0)
5358 (*num_tdls_vifs)++;
5359}
5360
5361static int ath10k_mac_tdls_vifs_count(struct ieee80211_hw *hw)
5362{
5363 int num_tdls_vifs = 0;
5364
5365 ieee80211_iterate_active_interfaces_atomic(hw,
5366 IEEE80211_IFACE_ITER_NORMAL,
5367 ath10k_mac_tdls_vifs_count_iter,
5368 &num_tdls_vifs);
5369 return num_tdls_vifs;
5370}
5371
Kalle Valo5e3dd152013-06-12 20:52:10 +03005372static int ath10k_sta_state(struct ieee80211_hw *hw,
5373 struct ieee80211_vif *vif,
5374 struct ieee80211_sta *sta,
5375 enum ieee80211_sta_state old_state,
5376 enum ieee80211_sta_state new_state)
5377{
5378 struct ath10k *ar = hw->priv;
5379 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kazior9797feb2014-02-14 14:49:48 +01005380 struct ath10k_sta *arsta = (struct ath10k_sta *)sta->drv_priv;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005381 int ret = 0;
5382
Michal Kazior76f90022014-02-25 09:29:57 +02005383 if (old_state == IEEE80211_STA_NOTEXIST &&
5384 new_state == IEEE80211_STA_NONE) {
5385 memset(arsta, 0, sizeof(*arsta));
5386 arsta->arvif = arvif;
5387 INIT_WORK(&arsta->update_wk, ath10k_sta_rc_update_wk);
5388 }
5389
Michal Kazior9797feb2014-02-14 14:49:48 +01005390 /* cancel must be done outside the mutex to avoid deadlock */
5391 if ((old_state == IEEE80211_STA_NONE &&
5392 new_state == IEEE80211_STA_NOTEXIST))
5393 cancel_work_sync(&arsta->update_wk);
5394
Kalle Valo5e3dd152013-06-12 20:52:10 +03005395 mutex_lock(&ar->conf_mutex);
5396
5397 if (old_state == IEEE80211_STA_NOTEXIST &&
Michal Kazior077efc82014-10-21 10:10:29 +03005398 new_state == IEEE80211_STA_NONE) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03005399 /*
5400 * New station addition.
5401 */
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005402 enum wmi_peer_type peer_type = WMI_PEER_TYPE_DEFAULT;
5403 u32 num_tdls_stations;
5404 u32 num_tdls_vifs;
5405
Michal Kaziorcfd10612014-11-25 15:16:05 +01005406 ath10k_dbg(ar, ATH10K_DBG_MAC,
5407 "mac vdev %d peer create %pM (new sta) sta %d / %d peer %d / %d\n",
5408 arvif->vdev_id, sta->addr,
5409 ar->num_stations + 1, ar->max_num_stations,
5410 ar->num_peers + 1, ar->max_num_peers);
Bartosz Markowski0e759f32014-01-02 14:38:33 +01005411
Marek Puzyniak7c354242015-03-30 09:51:52 +03005412 ret = ath10k_mac_inc_num_stations(arvif, sta);
Michal Kaziorcfd10612014-11-25 15:16:05 +01005413 if (ret) {
5414 ath10k_warn(ar, "refusing to associate station: too many connected already (%d)\n",
5415 ar->max_num_stations);
Bartosz Markowski0e759f32014-01-02 14:38:33 +01005416 goto exit;
5417 }
5418
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005419 if (sta->tdls)
5420 peer_type = WMI_PEER_TYPE_TDLS;
5421
Marek Puzyniak7390ed32015-03-30 09:51:52 +03005422 ret = ath10k_peer_create(ar, arvif->vdev_id, sta->addr,
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005423 peer_type);
Michal Kaziora52c0282014-11-25 15:16:03 +01005424 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005425 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 -08005426 sta->addr, arvif->vdev_id, ret);
Marek Puzyniak7c354242015-03-30 09:51:52 +03005427 ath10k_mac_dec_num_stations(arvif, sta);
Michal Kaziora52c0282014-11-25 15:16:03 +01005428 goto exit;
5429 }
Michal Kazior077efc82014-10-21 10:10:29 +03005430
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005431 if (!sta->tdls)
5432 goto exit;
Michal Kazior077efc82014-10-21 10:10:29 +03005433
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005434 num_tdls_stations = ath10k_mac_tdls_vif_stations_count(hw, vif);
5435 num_tdls_vifs = ath10k_mac_tdls_vifs_count(hw);
5436
5437 if (num_tdls_vifs >= ar->max_num_tdls_vdevs &&
5438 num_tdls_stations == 0) {
5439 ath10k_warn(ar, "vdev %i exceeded maximum number of tdls vdevs %i\n",
5440 arvif->vdev_id, ar->max_num_tdls_vdevs);
5441 ath10k_peer_delete(ar, arvif->vdev_id, sta->addr);
5442 ath10k_mac_dec_num_stations(arvif, sta);
5443 ret = -ENOBUFS;
5444 goto exit;
5445 }
5446
5447 if (num_tdls_stations == 0) {
5448 /* This is the first tdls peer in current vif */
5449 enum wmi_tdls_state state = WMI_TDLS_ENABLE_ACTIVE;
5450
5451 ret = ath10k_wmi_update_fw_tdls_state(ar, arvif->vdev_id,
5452 state);
Michal Kazior077efc82014-10-21 10:10:29 +03005453 if (ret) {
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005454 ath10k_warn(ar, "failed to update fw tdls state on vdev %i: %i\n",
Michal Kazior077efc82014-10-21 10:10:29 +03005455 arvif->vdev_id, ret);
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005456 ath10k_peer_delete(ar, arvif->vdev_id,
5457 sta->addr);
5458 ath10k_mac_dec_num_stations(arvif, sta);
Michal Kazior077efc82014-10-21 10:10:29 +03005459 goto exit;
5460 }
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005461 }
Michal Kazior077efc82014-10-21 10:10:29 +03005462
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005463 ret = ath10k_mac_tdls_peer_update(ar, arvif->vdev_id, sta,
5464 WMI_TDLS_PEER_STATE_PEERING);
5465 if (ret) {
5466 ath10k_warn(ar,
5467 "failed to update tdls peer %pM for vdev %d when adding a new sta: %i\n",
5468 sta->addr, arvif->vdev_id, ret);
5469 ath10k_peer_delete(ar, arvif->vdev_id, sta->addr);
5470 ath10k_mac_dec_num_stations(arvif, sta);
5471
5472 if (num_tdls_stations != 0)
5473 goto exit;
5474 ath10k_wmi_update_fw_tdls_state(ar, arvif->vdev_id,
5475 WMI_TDLS_DISABLE);
Michal Kazior077efc82014-10-21 10:10:29 +03005476 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03005477 } else if ((old_state == IEEE80211_STA_NONE &&
5478 new_state == IEEE80211_STA_NOTEXIST)) {
5479 /*
5480 * Existing station deletion.
5481 */
Michal Kazior7aa7a722014-08-25 12:09:38 +02005482 ath10k_dbg(ar, ATH10K_DBG_MAC,
Kalle Valo60c3daa2013-09-08 17:56:07 +03005483 "mac vdev %d peer delete %pM (sta gone)\n",
5484 arvif->vdev_id, sta->addr);
Michal Kazior077efc82014-10-21 10:10:29 +03005485
Kalle Valo5e3dd152013-06-12 20:52:10 +03005486 ret = ath10k_peer_delete(ar, arvif->vdev_id, sta->addr);
5487 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005488 ath10k_warn(ar, "failed to delete peer %pM for vdev %d: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02005489 sta->addr, arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005490
Marek Puzyniak7c354242015-03-30 09:51:52 +03005491 ath10k_mac_dec_num_stations(arvif, sta);
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005492
5493 if (!sta->tdls)
5494 goto exit;
5495
5496 if (ath10k_mac_tdls_vif_stations_count(hw, vif))
5497 goto exit;
5498
5499 /* This was the last tdls peer in current vif */
5500 ret = ath10k_wmi_update_fw_tdls_state(ar, arvif->vdev_id,
5501 WMI_TDLS_DISABLE);
5502 if (ret) {
5503 ath10k_warn(ar, "failed to update fw tdls state on vdev %i: %i\n",
5504 arvif->vdev_id, ret);
5505 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03005506 } else if (old_state == IEEE80211_STA_AUTH &&
5507 new_state == IEEE80211_STA_ASSOC &&
5508 (vif->type == NL80211_IFTYPE_AP ||
Bob Copelandb6c7baf2015-09-09 12:47:36 -04005509 vif->type == NL80211_IFTYPE_MESH_POINT ||
Kalle Valo5e3dd152013-06-12 20:52:10 +03005510 vif->type == NL80211_IFTYPE_ADHOC)) {
5511 /*
5512 * New association.
5513 */
Michal Kazior7aa7a722014-08-25 12:09:38 +02005514 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac sta %pM associated\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03005515 sta->addr);
5516
Michal Kazior590922a2014-10-21 10:10:29 +03005517 ret = ath10k_station_assoc(ar, vif, sta, false);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005518 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005519 ath10k_warn(ar, "failed to associate station %pM for vdev %i: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02005520 sta->addr, arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005521 } else if (old_state == IEEE80211_STA_ASSOC &&
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005522 new_state == IEEE80211_STA_AUTHORIZED &&
5523 sta->tdls) {
5524 /*
5525 * Tdls station authorized.
5526 */
5527 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac tdls sta %pM authorized\n",
5528 sta->addr);
5529
5530 ret = ath10k_station_assoc(ar, vif, sta, false);
5531 if (ret) {
5532 ath10k_warn(ar, "failed to associate tdls station %pM for vdev %i: %i\n",
5533 sta->addr, arvif->vdev_id, ret);
5534 goto exit;
5535 }
5536
5537 ret = ath10k_mac_tdls_peer_update(ar, arvif->vdev_id, sta,
5538 WMI_TDLS_PEER_STATE_CONNECTED);
5539 if (ret)
5540 ath10k_warn(ar, "failed to update tdls peer %pM for vdev %i: %i\n",
5541 sta->addr, arvif->vdev_id, ret);
5542 } else if (old_state == IEEE80211_STA_ASSOC &&
5543 new_state == IEEE80211_STA_AUTH &&
5544 (vif->type == NL80211_IFTYPE_AP ||
Bob Copelandb6c7baf2015-09-09 12:47:36 -04005545 vif->type == NL80211_IFTYPE_MESH_POINT ||
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03005546 vif->type == NL80211_IFTYPE_ADHOC)) {
Kalle Valo5e3dd152013-06-12 20:52:10 +03005547 /*
5548 * Disassociation.
5549 */
Michal Kazior7aa7a722014-08-25 12:09:38 +02005550 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac sta %pM disassociated\n",
Kalle Valo60c3daa2013-09-08 17:56:07 +03005551 sta->addr);
5552
Michal Kazior590922a2014-10-21 10:10:29 +03005553 ret = ath10k_station_disassoc(ar, vif, sta);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005554 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005555 ath10k_warn(ar, "failed to disassociate station: %pM vdev %i: %i\n",
Ben Greear69244e52014-02-27 18:50:00 +02005556 sta->addr, arvif->vdev_id, ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005557 }
Bartosz Markowski0e759f32014-01-02 14:38:33 +01005558exit:
Kalle Valo5e3dd152013-06-12 20:52:10 +03005559 mutex_unlock(&ar->conf_mutex);
5560 return ret;
5561}
5562
5563static int ath10k_conf_tx_uapsd(struct ath10k *ar, struct ieee80211_vif *vif,
Kalle Valo5b07e072014-09-14 12:50:06 +03005564 u16 ac, bool enable)
Kalle Valo5e3dd152013-06-12 20:52:10 +03005565{
5566 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kaziorb0e56152015-01-24 12:14:52 +02005567 struct wmi_sta_uapsd_auto_trig_arg arg = {};
5568 u32 prio = 0, acc = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005569 u32 value = 0;
5570 int ret = 0;
5571
Michal Kazior548db542013-07-05 16:15:15 +03005572 lockdep_assert_held(&ar->conf_mutex);
5573
Kalle Valo5e3dd152013-06-12 20:52:10 +03005574 if (arvif->vdev_type != WMI_VDEV_TYPE_STA)
5575 return 0;
5576
5577 switch (ac) {
5578 case IEEE80211_AC_VO:
5579 value = WMI_STA_PS_UAPSD_AC3_DELIVERY_EN |
5580 WMI_STA_PS_UAPSD_AC3_TRIGGER_EN;
Michal Kaziorb0e56152015-01-24 12:14:52 +02005581 prio = 7;
5582 acc = 3;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005583 break;
5584 case IEEE80211_AC_VI:
5585 value = WMI_STA_PS_UAPSD_AC2_DELIVERY_EN |
5586 WMI_STA_PS_UAPSD_AC2_TRIGGER_EN;
Michal Kaziorb0e56152015-01-24 12:14:52 +02005587 prio = 5;
5588 acc = 2;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005589 break;
5590 case IEEE80211_AC_BE:
5591 value = WMI_STA_PS_UAPSD_AC1_DELIVERY_EN |
5592 WMI_STA_PS_UAPSD_AC1_TRIGGER_EN;
Michal Kaziorb0e56152015-01-24 12:14:52 +02005593 prio = 2;
5594 acc = 1;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005595 break;
5596 case IEEE80211_AC_BK:
5597 value = WMI_STA_PS_UAPSD_AC0_DELIVERY_EN |
5598 WMI_STA_PS_UAPSD_AC0_TRIGGER_EN;
Michal Kaziorb0e56152015-01-24 12:14:52 +02005599 prio = 0;
5600 acc = 0;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005601 break;
5602 }
5603
5604 if (enable)
5605 arvif->u.sta.uapsd |= value;
5606 else
5607 arvif->u.sta.uapsd &= ~value;
5608
5609 ret = ath10k_wmi_set_sta_ps_param(ar, arvif->vdev_id,
5610 WMI_STA_PS_PARAM_UAPSD,
5611 arvif->u.sta.uapsd);
5612 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005613 ath10k_warn(ar, "failed to set uapsd params: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005614 goto exit;
5615 }
5616
5617 if (arvif->u.sta.uapsd)
5618 value = WMI_STA_PS_RX_WAKE_POLICY_POLL_UAPSD;
5619 else
5620 value = WMI_STA_PS_RX_WAKE_POLICY_WAKE;
5621
5622 ret = ath10k_wmi_set_sta_ps_param(ar, arvif->vdev_id,
5623 WMI_STA_PS_PARAM_RX_WAKE_POLICY,
5624 value);
5625 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005626 ath10k_warn(ar, "failed to set rx wake param: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005627
Michal Kazior9f9b5742014-12-12 12:41:36 +01005628 ret = ath10k_mac_vif_recalc_ps_wake_threshold(arvif);
5629 if (ret) {
5630 ath10k_warn(ar, "failed to recalc ps wake threshold on vdev %i: %d\n",
5631 arvif->vdev_id, ret);
5632 return ret;
5633 }
5634
5635 ret = ath10k_mac_vif_recalc_ps_poll_count(arvif);
5636 if (ret) {
5637 ath10k_warn(ar, "failed to recalc ps poll count on vdev %i: %d\n",
5638 arvif->vdev_id, ret);
5639 return ret;
5640 }
5641
Michal Kaziorb0e56152015-01-24 12:14:52 +02005642 if (test_bit(WMI_SERVICE_STA_UAPSD_BASIC_AUTO_TRIG, ar->wmi.svc_map) ||
5643 test_bit(WMI_SERVICE_STA_UAPSD_VAR_AUTO_TRIG, ar->wmi.svc_map)) {
5644 /* Only userspace can make an educated decision when to send
5645 * trigger frame. The following effectively disables u-UAPSD
5646 * autotrigger in firmware (which is enabled by default
5647 * provided the autotrigger service is available).
5648 */
5649
5650 arg.wmm_ac = acc;
5651 arg.user_priority = prio;
5652 arg.service_interval = 0;
5653 arg.suspend_interval = WMI_STA_UAPSD_MAX_INTERVAL_MSEC;
5654 arg.delay_interval = WMI_STA_UAPSD_MAX_INTERVAL_MSEC;
5655
5656 ret = ath10k_wmi_vdev_sta_uapsd(ar, arvif->vdev_id,
5657 arvif->bssid, &arg, 1);
5658 if (ret) {
5659 ath10k_warn(ar, "failed to set uapsd auto trigger %d\n",
5660 ret);
5661 return ret;
5662 }
5663 }
5664
Kalle Valo5e3dd152013-06-12 20:52:10 +03005665exit:
5666 return ret;
5667}
5668
5669static int ath10k_conf_tx(struct ieee80211_hw *hw,
5670 struct ieee80211_vif *vif, u16 ac,
5671 const struct ieee80211_tx_queue_params *params)
5672{
5673 struct ath10k *ar = hw->priv;
Michal Kazior5e752e42015-01-19 09:53:41 +01005674 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005675 struct wmi_wmm_params_arg *p = NULL;
5676 int ret;
5677
5678 mutex_lock(&ar->conf_mutex);
5679
5680 switch (ac) {
5681 case IEEE80211_AC_VO:
Michal Kazior5e752e42015-01-19 09:53:41 +01005682 p = &arvif->wmm_params.ac_vo;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005683 break;
5684 case IEEE80211_AC_VI:
Michal Kazior5e752e42015-01-19 09:53:41 +01005685 p = &arvif->wmm_params.ac_vi;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005686 break;
5687 case IEEE80211_AC_BE:
Michal Kazior5e752e42015-01-19 09:53:41 +01005688 p = &arvif->wmm_params.ac_be;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005689 break;
5690 case IEEE80211_AC_BK:
Michal Kazior5e752e42015-01-19 09:53:41 +01005691 p = &arvif->wmm_params.ac_bk;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005692 break;
5693 }
5694
5695 if (WARN_ON(!p)) {
5696 ret = -EINVAL;
5697 goto exit;
5698 }
5699
5700 p->cwmin = params->cw_min;
5701 p->cwmax = params->cw_max;
5702 p->aifs = params->aifs;
5703
5704 /*
5705 * The channel time duration programmed in the HW is in absolute
5706 * microseconds, while mac80211 gives the txop in units of
5707 * 32 microseconds.
5708 */
5709 p->txop = params->txop * 32;
5710
Michal Kazior7fc979a2015-01-28 09:57:28 +02005711 if (ar->wmi.ops->gen_vdev_wmm_conf) {
5712 ret = ath10k_wmi_vdev_wmm_conf(ar, arvif->vdev_id,
5713 &arvif->wmm_params);
5714 if (ret) {
5715 ath10k_warn(ar, "failed to set vdev wmm params on vdev %i: %d\n",
5716 arvif->vdev_id, ret);
5717 goto exit;
5718 }
5719 } else {
5720 /* This won't work well with multi-interface cases but it's
5721 * better than nothing.
5722 */
5723 ret = ath10k_wmi_pdev_set_wmm_params(ar, &arvif->wmm_params);
5724 if (ret) {
5725 ath10k_warn(ar, "failed to set wmm params: %d\n", ret);
5726 goto exit;
5727 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03005728 }
5729
5730 ret = ath10k_conf_tx_uapsd(ar, vif, ac, params->uapsd);
5731 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005732 ath10k_warn(ar, "failed to set sta uapsd: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005733
5734exit:
5735 mutex_unlock(&ar->conf_mutex);
5736 return ret;
5737}
5738
5739#define ATH10K_ROC_TIMEOUT_HZ (2*HZ)
5740
5741static int ath10k_remain_on_channel(struct ieee80211_hw *hw,
5742 struct ieee80211_vif *vif,
5743 struct ieee80211_channel *chan,
5744 int duration,
5745 enum ieee80211_roc_type type)
5746{
5747 struct ath10k *ar = hw->priv;
5748 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
5749 struct wmi_start_scan_arg arg;
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005750 int ret = 0;
Michal Kaziorfcf98442015-03-31 11:03:47 +00005751 u32 scan_time_msec;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005752
5753 mutex_lock(&ar->conf_mutex);
5754
5755 spin_lock_bh(&ar->data_lock);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005756 switch (ar->scan.state) {
5757 case ATH10K_SCAN_IDLE:
5758 reinit_completion(&ar->scan.started);
5759 reinit_completion(&ar->scan.completed);
5760 reinit_completion(&ar->scan.on_channel);
5761 ar->scan.state = ATH10K_SCAN_STARTING;
5762 ar->scan.is_roc = true;
5763 ar->scan.vdev_id = arvif->vdev_id;
5764 ar->scan.roc_freq = chan->center_freq;
Michal Kaziord710e752015-07-09 13:08:36 +02005765 ar->scan.roc_notify = true;
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005766 ret = 0;
5767 break;
5768 case ATH10K_SCAN_STARTING:
5769 case ATH10K_SCAN_RUNNING:
5770 case ATH10K_SCAN_ABORTING:
Kalle Valo5e3dd152013-06-12 20:52:10 +03005771 ret = -EBUSY;
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005772 break;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005773 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03005774 spin_unlock_bh(&ar->data_lock);
5775
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005776 if (ret)
5777 goto exit;
5778
Michal Kaziorfcf98442015-03-31 11:03:47 +00005779 scan_time_msec = ar->hw->wiphy->max_remain_on_channel_duration * 2;
Michal Kaziordcca0bd2014-11-24 14:58:32 +01005780
Kalle Valo5e3dd152013-06-12 20:52:10 +03005781 memset(&arg, 0, sizeof(arg));
5782 ath10k_wmi_start_scan_init(ar, &arg);
5783 arg.vdev_id = arvif->vdev_id;
5784 arg.scan_id = ATH10K_SCAN_ID;
5785 arg.n_channels = 1;
5786 arg.channels[0] = chan->center_freq;
Michal Kaziorfcf98442015-03-31 11:03:47 +00005787 arg.dwell_time_active = scan_time_msec;
5788 arg.dwell_time_passive = scan_time_msec;
5789 arg.max_scan_time = scan_time_msec;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005790 arg.scan_ctrl_flags |= WMI_SCAN_FLAG_PASSIVE;
5791 arg.scan_ctrl_flags |= WMI_SCAN_FILTER_PROBE_REQ;
Michal Kaziordbd3f9f2015-03-31 11:03:48 +00005792 arg.burst_duration_ms = duration;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005793
5794 ret = ath10k_start_scan(ar, &arg);
5795 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005796 ath10k_warn(ar, "failed to start roc scan: %d\n", ret);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005797 spin_lock_bh(&ar->data_lock);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005798 ar->scan.state = ATH10K_SCAN_IDLE;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005799 spin_unlock_bh(&ar->data_lock);
5800 goto exit;
5801 }
5802
5803 ret = wait_for_completion_timeout(&ar->scan.on_channel, 3*HZ);
5804 if (ret == 0) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005805 ath10k_warn(ar, "failed to switch to channel for roc scan\n");
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005806
5807 ret = ath10k_scan_stop(ar);
5808 if (ret)
Michal Kazior7aa7a722014-08-25 12:09:38 +02005809 ath10k_warn(ar, "failed to stop scan: %d\n", ret);
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005810
Kalle Valo5e3dd152013-06-12 20:52:10 +03005811 ret = -ETIMEDOUT;
5812 goto exit;
5813 }
5814
Michal Kaziorfcf98442015-03-31 11:03:47 +00005815 ieee80211_queue_delayed_work(ar->hw, &ar->scan.timeout,
5816 msecs_to_jiffies(duration));
5817
Kalle Valo5e3dd152013-06-12 20:52:10 +03005818 ret = 0;
5819exit:
5820 mutex_unlock(&ar->conf_mutex);
5821 return ret;
5822}
5823
5824static int ath10k_cancel_remain_on_channel(struct ieee80211_hw *hw)
5825{
5826 struct ath10k *ar = hw->priv;
5827
5828 mutex_lock(&ar->conf_mutex);
Michal Kaziord710e752015-07-09 13:08:36 +02005829
5830 spin_lock_bh(&ar->data_lock);
5831 ar->scan.roc_notify = false;
5832 spin_unlock_bh(&ar->data_lock);
5833
Michal Kazior5c81c7f2014-08-05 14:54:44 +02005834 ath10k_scan_abort(ar);
Michal Kaziord710e752015-07-09 13:08:36 +02005835
Kalle Valo5e3dd152013-06-12 20:52:10 +03005836 mutex_unlock(&ar->conf_mutex);
5837
Michal Kazior4eb2e162014-10-28 10:23:09 +01005838 cancel_delayed_work_sync(&ar->scan.timeout);
5839
Kalle Valo5e3dd152013-06-12 20:52:10 +03005840 return 0;
5841}
5842
5843/*
5844 * Both RTS and Fragmentation threshold are interface-specific
5845 * in ath10k, but device-specific in mac80211.
5846 */
Kalle Valo5e3dd152013-06-12 20:52:10 +03005847
5848static int ath10k_set_rts_threshold(struct ieee80211_hw *hw, u32 value)
5849{
Kalle Valo5e3dd152013-06-12 20:52:10 +03005850 struct ath10k *ar = hw->priv;
Michal Kaziorad088bf2013-10-16 15:44:46 +03005851 struct ath10k_vif *arvif;
5852 int ret = 0;
Michal Kazior548db542013-07-05 16:15:15 +03005853
Michal Kaziorad088bf2013-10-16 15:44:46 +03005854 mutex_lock(&ar->conf_mutex);
5855 list_for_each_entry(arvif, &ar->arvifs, list) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005856 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac vdev %d rts threshold %d\n",
Michal Kaziorad088bf2013-10-16 15:44:46 +03005857 arvif->vdev_id, value);
Kalle Valo60c3daa2013-09-08 17:56:07 +03005858
Michal Kaziorad088bf2013-10-16 15:44:46 +03005859 ret = ath10k_mac_set_rts(arvif, value);
5860 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005861 ath10k_warn(ar, "failed to set rts threshold for vdev %d: %d\n",
Michal Kaziorad088bf2013-10-16 15:44:46 +03005862 arvif->vdev_id, ret);
5863 break;
5864 }
5865 }
5866 mutex_unlock(&ar->conf_mutex);
5867
5868 return ret;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005869}
5870
Michal Kazior92092fe2015-08-03 11:16:43 +02005871static int ath10k_mac_op_set_frag_threshold(struct ieee80211_hw *hw, u32 value)
5872{
5873 /* Even though there's a WMI enum for fragmentation threshold no known
5874 * firmware actually implements it. Moreover it is not possible to rely
5875 * frame fragmentation to mac80211 because firmware clears the "more
5876 * fragments" bit in frame control making it impossible for remote
5877 * devices to reassemble frames.
5878 *
5879 * Hence implement a dummy callback just to say fragmentation isn't
5880 * supported. This effectively prevents mac80211 from doing frame
5881 * fragmentation in software.
5882 */
5883 return -EOPNOTSUPP;
5884}
5885
Emmanuel Grumbach77be2c52014-03-27 11:30:29 +02005886static void ath10k_flush(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
5887 u32 queues, bool drop)
Kalle Valo5e3dd152013-06-12 20:52:10 +03005888{
5889 struct ath10k *ar = hw->priv;
Michal Kazioraffd3212013-07-16 09:54:35 +02005890 bool skip;
Nicholas Mc Guired4298a32015-06-15 14:46:43 +03005891 long time_left;
Kalle Valo5e3dd152013-06-12 20:52:10 +03005892
5893 /* mac80211 doesn't care if we really xmit queued frames or not
5894 * we'll collect those frames either way if we stop/delete vdevs */
5895 if (drop)
5896 return;
5897
Michal Kazior548db542013-07-05 16:15:15 +03005898 mutex_lock(&ar->conf_mutex);
5899
Michal Kazioraffd3212013-07-16 09:54:35 +02005900 if (ar->state == ATH10K_STATE_WEDGED)
5901 goto skip;
5902
Nicholas Mc Guired4298a32015-06-15 14:46:43 +03005903 time_left = wait_event_timeout(ar->htt.empty_tx_wq, ({
Kalle Valo5e3dd152013-06-12 20:52:10 +03005904 bool empty;
Michal Kazioraffd3212013-07-16 09:54:35 +02005905
Michal Kazioredb82362013-07-05 16:15:14 +03005906 spin_lock_bh(&ar->htt.tx_lock);
Michal Kazior0945baf2013-09-18 14:43:18 +02005907 empty = (ar->htt.num_pending_tx == 0);
Michal Kazioredb82362013-07-05 16:15:14 +03005908 spin_unlock_bh(&ar->htt.tx_lock);
Michal Kazioraffd3212013-07-16 09:54:35 +02005909
Michal Kazior7962b0d2014-10-28 10:34:38 +01005910 skip = (ar->state == ATH10K_STATE_WEDGED) ||
5911 test_bit(ATH10K_FLAG_CRASH_FLUSH,
5912 &ar->dev_flags);
Michal Kazioraffd3212013-07-16 09:54:35 +02005913
5914 (empty || skip);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005915 }), ATH10K_FLUSH_TIMEOUT_HZ);
Michal Kazioraffd3212013-07-16 09:54:35 +02005916
Nicholas Mc Guired4298a32015-06-15 14:46:43 +03005917 if (time_left == 0 || skip)
5918 ath10k_warn(ar, "failed to flush transmit queue (skip %i ar-state %i): %ld\n",
5919 skip, ar->state, time_left);
Michal Kazior548db542013-07-05 16:15:15 +03005920
Michal Kazioraffd3212013-07-16 09:54:35 +02005921skip:
Michal Kazior548db542013-07-05 16:15:15 +03005922 mutex_unlock(&ar->conf_mutex);
Kalle Valo5e3dd152013-06-12 20:52:10 +03005923}
5924
5925/* TODO: Implement this function properly
5926 * For now it is needed to reply to Probe Requests in IBSS mode.
5927 * Propably we need this information from FW.
5928 */
5929static int ath10k_tx_last_beacon(struct ieee80211_hw *hw)
5930{
5931 return 1;
5932}
5933
Eliad Pellercf2c92d2014-11-04 11:43:54 +02005934static void ath10k_reconfig_complete(struct ieee80211_hw *hw,
5935 enum ieee80211_reconfig_type reconfig_type)
Michal Kazioraffd3212013-07-16 09:54:35 +02005936{
5937 struct ath10k *ar = hw->priv;
5938
Eliad Pellercf2c92d2014-11-04 11:43:54 +02005939 if (reconfig_type != IEEE80211_RECONFIG_TYPE_RESTART)
5940 return;
5941
Michal Kazioraffd3212013-07-16 09:54:35 +02005942 mutex_lock(&ar->conf_mutex);
5943
5944 /* If device failed to restart it will be in a different state, e.g.
5945 * ATH10K_STATE_WEDGED */
5946 if (ar->state == ATH10K_STATE_RESTARTED) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02005947 ath10k_info(ar, "device successfully recovered\n");
Michal Kazioraffd3212013-07-16 09:54:35 +02005948 ar->state = ATH10K_STATE_ON;
Michal Kazior7962b0d2014-10-28 10:34:38 +01005949 ieee80211_wake_queues(ar->hw);
Michal Kazioraffd3212013-07-16 09:54:35 +02005950 }
5951
5952 mutex_unlock(&ar->conf_mutex);
5953}
5954
Michal Kazior2e1dea42013-07-31 10:32:40 +02005955static int ath10k_get_survey(struct ieee80211_hw *hw, int idx,
5956 struct survey_info *survey)
5957{
5958 struct ath10k *ar = hw->priv;
5959 struct ieee80211_supported_band *sband;
5960 struct survey_info *ar_survey = &ar->survey[idx];
5961 int ret = 0;
5962
5963 mutex_lock(&ar->conf_mutex);
5964
5965 sband = hw->wiphy->bands[IEEE80211_BAND_2GHZ];
5966 if (sband && idx >= sband->n_channels) {
5967 idx -= sband->n_channels;
5968 sband = NULL;
5969 }
5970
5971 if (!sband)
5972 sband = hw->wiphy->bands[IEEE80211_BAND_5GHZ];
5973
5974 if (!sband || idx >= sband->n_channels) {
5975 ret = -ENOENT;
5976 goto exit;
5977 }
5978
5979 spin_lock_bh(&ar->data_lock);
5980 memcpy(survey, ar_survey, sizeof(*survey));
5981 spin_unlock_bh(&ar->data_lock);
5982
5983 survey->channel = &sband->channels[idx];
5984
Felix Fietkaufa1d4df2014-10-23 17:04:28 +03005985 if (ar->rx_channel == survey->channel)
5986 survey->filled |= SURVEY_INFO_IN_USE;
5987
Michal Kazior2e1dea42013-07-31 10:32:40 +02005988exit:
5989 mutex_unlock(&ar->conf_mutex);
5990 return ret;
5991}
5992
Michal Kazior3ae54222015-03-31 10:49:20 +00005993static bool
5994ath10k_mac_bitrate_mask_has_single_rate(struct ath10k *ar,
5995 enum ieee80211_band band,
5996 const struct cfg80211_bitrate_mask *mask)
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01005997{
Michal Kazior3ae54222015-03-31 10:49:20 +00005998 int num_rates = 0;
5999 int i;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006000
Michal Kazior3ae54222015-03-31 10:49:20 +00006001 num_rates += hweight32(mask->control[band].legacy);
6002
6003 for (i = 0; i < ARRAY_SIZE(mask->control[band].ht_mcs); i++)
6004 num_rates += hweight8(mask->control[band].ht_mcs[i]);
6005
6006 for (i = 0; i < ARRAY_SIZE(mask->control[band].vht_mcs); i++)
6007 num_rates += hweight16(mask->control[band].vht_mcs[i]);
6008
6009 return num_rates == 1;
6010}
6011
6012static bool
6013ath10k_mac_bitrate_mask_get_single_nss(struct ath10k *ar,
6014 enum ieee80211_band band,
6015 const struct cfg80211_bitrate_mask *mask,
6016 int *nss)
6017{
6018 struct ieee80211_supported_band *sband = &ar->mac.sbands[band];
6019 u16 vht_mcs_map = le16_to_cpu(sband->vht_cap.vht_mcs.tx_mcs_map);
6020 u8 ht_nss_mask = 0;
6021 u8 vht_nss_mask = 0;
6022 int i;
6023
6024 if (mask->control[band].legacy)
6025 return false;
6026
6027 for (i = 0; i < ARRAY_SIZE(mask->control[band].ht_mcs); i++) {
6028 if (mask->control[band].ht_mcs[i] == 0)
6029 continue;
6030 else if (mask->control[band].ht_mcs[i] ==
6031 sband->ht_cap.mcs.rx_mask[i])
6032 ht_nss_mask |= BIT(i);
6033 else
6034 return false;
6035 }
6036
6037 for (i = 0; i < ARRAY_SIZE(mask->control[band].vht_mcs); i++) {
6038 if (mask->control[band].vht_mcs[i] == 0)
6039 continue;
6040 else if (mask->control[band].vht_mcs[i] ==
6041 ath10k_mac_get_max_vht_mcs_map(vht_mcs_map, i))
6042 vht_nss_mask |= BIT(i);
6043 else
6044 return false;
6045 }
6046
6047 if (ht_nss_mask != vht_nss_mask)
6048 return false;
6049
6050 if (ht_nss_mask == 0)
6051 return false;
6052
6053 if (BIT(fls(ht_nss_mask)) - 1 != ht_nss_mask)
6054 return false;
6055
6056 *nss = fls(ht_nss_mask);
6057
6058 return true;
6059}
6060
6061static int
6062ath10k_mac_bitrate_mask_get_single_rate(struct ath10k *ar,
6063 enum ieee80211_band band,
6064 const struct cfg80211_bitrate_mask *mask,
6065 u8 *rate, u8 *nss)
6066{
6067 struct ieee80211_supported_band *sband = &ar->mac.sbands[band];
6068 int rate_idx;
6069 int i;
6070 u16 bitrate;
6071 u8 preamble;
6072 u8 hw_rate;
6073
6074 if (hweight32(mask->control[band].legacy) == 1) {
6075 rate_idx = ffs(mask->control[band].legacy) - 1;
6076
6077 hw_rate = sband->bitrates[rate_idx].hw_value;
6078 bitrate = sband->bitrates[rate_idx].bitrate;
6079
6080 if (ath10k_mac_bitrate_is_cck(bitrate))
6081 preamble = WMI_RATE_PREAMBLE_CCK;
6082 else
6083 preamble = WMI_RATE_PREAMBLE_OFDM;
6084
6085 *nss = 1;
6086 *rate = preamble << 6 |
6087 (*nss - 1) << 4 |
6088 hw_rate << 0;
6089
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006090 return 0;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006091 }
6092
Michal Kazior3ae54222015-03-31 10:49:20 +00006093 for (i = 0; i < ARRAY_SIZE(mask->control[band].ht_mcs); i++) {
6094 if (hweight8(mask->control[band].ht_mcs[i]) == 1) {
6095 *nss = i + 1;
6096 *rate = WMI_RATE_PREAMBLE_HT << 6 |
6097 (*nss - 1) << 4 |
6098 (ffs(mask->control[band].ht_mcs[i]) - 1);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006099
Michal Kazior3ae54222015-03-31 10:49:20 +00006100 return 0;
6101 }
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006102 }
6103
Michal Kazior3ae54222015-03-31 10:49:20 +00006104 for (i = 0; i < ARRAY_SIZE(mask->control[band].vht_mcs); i++) {
6105 if (hweight16(mask->control[band].vht_mcs[i]) == 1) {
6106 *nss = i + 1;
6107 *rate = WMI_RATE_PREAMBLE_VHT << 6 |
6108 (*nss - 1) << 4 |
6109 (ffs(mask->control[band].vht_mcs[i]) - 1);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006110
Michal Kazior3ae54222015-03-31 10:49:20 +00006111 return 0;
6112 }
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006113 }
6114
Michal Kazior3ae54222015-03-31 10:49:20 +00006115 return -EINVAL;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006116}
6117
Michal Kazior3ae54222015-03-31 10:49:20 +00006118static int ath10k_mac_set_fixed_rate_params(struct ath10k_vif *arvif,
Rajkumar Manoharanbd4a41e2015-09-16 13:19:00 +05306119 u8 rate, u8 nss, u8 sgi, u8 ldpc)
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006120{
6121 struct ath10k *ar = arvif->ar;
6122 u32 vdev_param;
Michal Kazior3ae54222015-03-31 10:49:20 +00006123 int ret;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006124
Michal Kazior3ae54222015-03-31 10:49:20 +00006125 lockdep_assert_held(&ar->conf_mutex);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006126
Michal Kazior3ae54222015-03-31 10:49:20 +00006127 ath10k_dbg(ar, ATH10K_DBG_MAC, "mac set fixed rate params vdev %i rate 0x%02hhx nss %hhu sgi %hhu\n",
6128 arvif->vdev_id, rate, nss, sgi);
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01006129
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006130 vdev_param = ar->wmi.vdev_param->fixed_rate;
Michal Kazior3ae54222015-03-31 10:49:20 +00006131 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param, rate);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006132 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02006133 ath10k_warn(ar, "failed to set fixed rate param 0x%02x: %d\n",
Michal Kazior3ae54222015-03-31 10:49:20 +00006134 rate, ret);
6135 return ret;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006136 }
6137
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006138 vdev_param = ar->wmi.vdev_param->nss;
Michal Kazior3ae54222015-03-31 10:49:20 +00006139 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param, nss);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006140 if (ret) {
Michal Kazior3ae54222015-03-31 10:49:20 +00006141 ath10k_warn(ar, "failed to set nss param %d: %d\n", nss, ret);
6142 return ret;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006143 }
6144
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01006145 vdev_param = ar->wmi.vdev_param->sgi;
Michal Kazior3ae54222015-03-31 10:49:20 +00006146 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param, sgi);
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01006147 if (ret) {
Michal Kazior3ae54222015-03-31 10:49:20 +00006148 ath10k_warn(ar, "failed to set sgi param %d: %d\n", sgi, ret);
6149 return ret;
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01006150 }
6151
Rajkumar Manoharanbd4a41e2015-09-16 13:19:00 +05306152 vdev_param = ar->wmi.vdev_param->ldpc;
6153 ret = ath10k_wmi_vdev_set_param(ar, arvif->vdev_id, vdev_param, ldpc);
6154 if (ret) {
6155 ath10k_warn(ar, "failed to set ldpc param %d: %d\n", ldpc, ret);
6156 return ret;
6157 }
6158
Michal Kazior3ae54222015-03-31 10:49:20 +00006159 return 0;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006160}
6161
Michal Kazior45c9abc2015-04-21 20:42:58 +03006162static bool
6163ath10k_mac_can_set_bitrate_mask(struct ath10k *ar,
6164 enum ieee80211_band band,
6165 const struct cfg80211_bitrate_mask *mask)
6166{
6167 int i;
6168 u16 vht_mcs;
6169
6170 /* Due to firmware limitation in WMI_PEER_ASSOC_CMDID it is impossible
6171 * to express all VHT MCS rate masks. Effectively only the following
6172 * ranges can be used: none, 0-7, 0-8 and 0-9.
6173 */
6174 for (i = 0; i < NL80211_VHT_NSS_MAX; i++) {
6175 vht_mcs = mask->control[band].vht_mcs[i];
6176
6177 switch (vht_mcs) {
6178 case 0:
6179 case BIT(8) - 1:
6180 case BIT(9) - 1:
6181 case BIT(10) - 1:
6182 break;
6183 default:
6184 ath10k_warn(ar, "refusing bitrate mask with missing 0-7 VHT MCS rates\n");
6185 return false;
6186 }
6187 }
6188
6189 return true;
6190}
6191
6192static void ath10k_mac_set_bitrate_mask_iter(void *data,
6193 struct ieee80211_sta *sta)
6194{
6195 struct ath10k_vif *arvif = data;
6196 struct ath10k_sta *arsta = (struct ath10k_sta *)sta->drv_priv;
6197 struct ath10k *ar = arvif->ar;
6198
6199 if (arsta->arvif != arvif)
6200 return;
6201
6202 spin_lock_bh(&ar->data_lock);
6203 arsta->changed |= IEEE80211_RC_SUPP_RATES_CHANGED;
6204 spin_unlock_bh(&ar->data_lock);
6205
6206 ieee80211_queue_work(ar->hw, &arsta->update_wk);
6207}
6208
Michal Kazior3ae54222015-03-31 10:49:20 +00006209static int ath10k_mac_op_set_bitrate_mask(struct ieee80211_hw *hw,
6210 struct ieee80211_vif *vif,
6211 const struct cfg80211_bitrate_mask *mask)
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006212{
6213 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
Michal Kazior500ff9f2015-03-31 10:26:21 +00006214 struct cfg80211_chan_def def;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006215 struct ath10k *ar = arvif->ar;
Michal Kazior500ff9f2015-03-31 10:26:21 +00006216 enum ieee80211_band band;
Michal Kazior45c9abc2015-04-21 20:42:58 +03006217 const u8 *ht_mcs_mask;
6218 const u16 *vht_mcs_mask;
Michal Kazior3ae54222015-03-31 10:49:20 +00006219 u8 rate;
6220 u8 nss;
6221 u8 sgi;
Rajkumar Manoharanbd4a41e2015-09-16 13:19:00 +05306222 u8 ldpc;
Michal Kazior3ae54222015-03-31 10:49:20 +00006223 int single_nss;
6224 int ret;
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01006225
Michal Kazior500ff9f2015-03-31 10:26:21 +00006226 if (ath10k_mac_vif_chan(vif, &def))
6227 return -EPERM;
6228
Michal Kazior500ff9f2015-03-31 10:26:21 +00006229 band = def.chan->band;
Michal Kazior45c9abc2015-04-21 20:42:58 +03006230 ht_mcs_mask = mask->control[band].ht_mcs;
6231 vht_mcs_mask = mask->control[band].vht_mcs;
Rajkumar Manoharanbd4a41e2015-09-16 13:19:00 +05306232 ldpc = !!(ar->ht_cap_info & WMI_HT_CAP_LDPC);
Michal Kazior500ff9f2015-03-31 10:26:21 +00006233
Michal Kazior3ae54222015-03-31 10:49:20 +00006234 sgi = mask->control[band].gi;
6235 if (sgi == NL80211_TXRATE_FORCE_LGI)
Janusz Dziedzic9f81f722014-01-17 20:04:14 +01006236 return -EINVAL;
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006237
Michal Kazior3ae54222015-03-31 10:49:20 +00006238 if (ath10k_mac_bitrate_mask_has_single_rate(ar, band, mask)) {
6239 ret = ath10k_mac_bitrate_mask_get_single_rate(ar, band, mask,
6240 &rate, &nss);
6241 if (ret) {
6242 ath10k_warn(ar, "failed to get single rate for vdev %i: %d\n",
6243 arvif->vdev_id, ret);
6244 return ret;
6245 }
6246 } else if (ath10k_mac_bitrate_mask_get_single_nss(ar, band, mask,
6247 &single_nss)) {
6248 rate = WMI_FIXED_RATE_NONE;
6249 nss = single_nss;
6250 } else {
6251 rate = WMI_FIXED_RATE_NONE;
Michal Kazior45c9abc2015-04-21 20:42:58 +03006252 nss = min(ar->num_rf_chains,
6253 max(ath10k_mac_max_ht_nss(ht_mcs_mask),
6254 ath10k_mac_max_vht_nss(vht_mcs_mask)));
6255
6256 if (!ath10k_mac_can_set_bitrate_mask(ar, band, mask))
6257 return -EINVAL;
6258
6259 mutex_lock(&ar->conf_mutex);
6260
6261 arvif->bitrate_mask = *mask;
6262 ieee80211_iterate_stations_atomic(ar->hw,
6263 ath10k_mac_set_bitrate_mask_iter,
6264 arvif);
6265
6266 mutex_unlock(&ar->conf_mutex);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006267 }
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006268
6269 mutex_lock(&ar->conf_mutex);
6270
Rajkumar Manoharanbd4a41e2015-09-16 13:19:00 +05306271 ret = ath10k_mac_set_fixed_rate_params(arvif, rate, nss, sgi, ldpc);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006272 if (ret) {
Michal Kazior3ae54222015-03-31 10:49:20 +00006273 ath10k_warn(ar, "failed to set fixed rate params on vdev %i: %d\n",
6274 arvif->vdev_id, ret);
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006275 goto exit;
6276 }
6277
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006278exit:
6279 mutex_unlock(&ar->conf_mutex);
Michal Kazior3ae54222015-03-31 10:49:20 +00006280
Janusz Dziedzic51ab1a02014-01-08 09:08:33 +01006281 return ret;
6282}
6283
Michal Kazior9797feb2014-02-14 14:49:48 +01006284static void ath10k_sta_rc_update(struct ieee80211_hw *hw,
6285 struct ieee80211_vif *vif,
6286 struct ieee80211_sta *sta,
6287 u32 changed)
6288{
6289 struct ath10k *ar = hw->priv;
6290 struct ath10k_sta *arsta = (struct ath10k_sta *)sta->drv_priv;
6291 u32 bw, smps;
6292
6293 spin_lock_bh(&ar->data_lock);
6294
Michal Kazior7aa7a722014-08-25 12:09:38 +02006295 ath10k_dbg(ar, ATH10K_DBG_MAC,
Michal Kazior9797feb2014-02-14 14:49:48 +01006296 "mac sta rc update for %pM changed %08x bw %d nss %d smps %d\n",
6297 sta->addr, changed, sta->bandwidth, sta->rx_nss,
6298 sta->smps_mode);
6299
6300 if (changed & IEEE80211_RC_BW_CHANGED) {
6301 bw = WMI_PEER_CHWIDTH_20MHZ;
6302
6303 switch (sta->bandwidth) {
6304 case IEEE80211_STA_RX_BW_20:
6305 bw = WMI_PEER_CHWIDTH_20MHZ;
6306 break;
6307 case IEEE80211_STA_RX_BW_40:
6308 bw = WMI_PEER_CHWIDTH_40MHZ;
6309 break;
6310 case IEEE80211_STA_RX_BW_80:
6311 bw = WMI_PEER_CHWIDTH_80MHZ;
6312 break;
6313 case IEEE80211_STA_RX_BW_160:
Masanari Iidad939be32015-02-27 23:52:31 +09006314 ath10k_warn(ar, "Invalid bandwidth %d in rc update for %pM\n",
Kalle Valobe6546f2014-03-25 14:18:51 +02006315 sta->bandwidth, sta->addr);
Michal Kazior9797feb2014-02-14 14:49:48 +01006316 bw = WMI_PEER_CHWIDTH_20MHZ;
6317 break;
6318 }
6319
6320 arsta->bw = bw;
6321 }
6322
6323 if (changed & IEEE80211_RC_NSS_CHANGED)
6324 arsta->nss = sta->rx_nss;
6325
6326 if (changed & IEEE80211_RC_SMPS_CHANGED) {
6327 smps = WMI_PEER_SMPS_PS_NONE;
6328
6329 switch (sta->smps_mode) {
6330 case IEEE80211_SMPS_AUTOMATIC:
6331 case IEEE80211_SMPS_OFF:
6332 smps = WMI_PEER_SMPS_PS_NONE;
6333 break;
6334 case IEEE80211_SMPS_STATIC:
6335 smps = WMI_PEER_SMPS_STATIC;
6336 break;
6337 case IEEE80211_SMPS_DYNAMIC:
6338 smps = WMI_PEER_SMPS_DYNAMIC;
6339 break;
6340 case IEEE80211_SMPS_NUM_MODES:
Michal Kazior7aa7a722014-08-25 12:09:38 +02006341 ath10k_warn(ar, "Invalid smps %d in sta rc update for %pM\n",
Kalle Valobe6546f2014-03-25 14:18:51 +02006342 sta->smps_mode, sta->addr);
Michal Kazior9797feb2014-02-14 14:49:48 +01006343 smps = WMI_PEER_SMPS_PS_NONE;
6344 break;
6345 }
6346
6347 arsta->smps = smps;
6348 }
6349
Michal Kazior9797feb2014-02-14 14:49:48 +01006350 arsta->changed |= changed;
6351
6352 spin_unlock_bh(&ar->data_lock);
6353
6354 ieee80211_queue_work(hw, &arsta->update_wk);
6355}
6356
Chun-Yeow Yeoh26ebbcc2014-02-25 09:29:54 +02006357static u64 ath10k_get_tsf(struct ieee80211_hw *hw, struct ieee80211_vif *vif)
6358{
6359 /*
6360 * FIXME: Return 0 for time being. Need to figure out whether FW
6361 * has the API to fetch 64-bit local TSF
6362 */
6363
6364 return 0;
6365}
6366
Michal Kazioraa5b4fb2014-07-23 12:20:33 +02006367static int ath10k_ampdu_action(struct ieee80211_hw *hw,
6368 struct ieee80211_vif *vif,
6369 enum ieee80211_ampdu_mlme_action action,
6370 struct ieee80211_sta *sta, u16 tid, u16 *ssn,
Emmanuel Grumbache3abc8f2015-08-16 11:13:22 +03006371 u8 buf_size, bool amsdu)
Michal Kazioraa5b4fb2014-07-23 12:20:33 +02006372{
Michal Kazior7aa7a722014-08-25 12:09:38 +02006373 struct ath10k *ar = hw->priv;
Michal Kazioraa5b4fb2014-07-23 12:20:33 +02006374 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
6375
Michal Kazior7aa7a722014-08-25 12:09:38 +02006376 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 +02006377 arvif->vdev_id, sta->addr, tid, action);
6378
6379 switch (action) {
6380 case IEEE80211_AMPDU_RX_START:
6381 case IEEE80211_AMPDU_RX_STOP:
6382 /* HTT AddBa/DelBa events trigger mac80211 Rx BA session
6383 * creation/removal. Do we need to verify this?
6384 */
6385 return 0;
6386 case IEEE80211_AMPDU_TX_START:
6387 case IEEE80211_AMPDU_TX_STOP_CONT:
6388 case IEEE80211_AMPDU_TX_STOP_FLUSH:
6389 case IEEE80211_AMPDU_TX_STOP_FLUSH_CONT:
6390 case IEEE80211_AMPDU_TX_OPERATIONAL:
6391 /* Firmware offloads Tx aggregation entirely so deny mac80211
6392 * Tx aggregation requests.
6393 */
6394 return -EOPNOTSUPP;
6395 }
6396
6397 return -EINVAL;
6398}
6399
Michal Kazior500ff9f2015-03-31 10:26:21 +00006400static void
Michal Kaziord7bf4b42015-06-03 12:16:54 +02006401ath10k_mac_update_rx_channel(struct ath10k *ar,
6402 struct ieee80211_chanctx_conf *ctx,
6403 struct ieee80211_vif_chanctx_switch *vifs,
6404 int n_vifs)
Michal Kazior500ff9f2015-03-31 10:26:21 +00006405{
6406 struct cfg80211_chan_def *def = NULL;
6407
6408 /* Both locks are required because ar->rx_channel is modified. This
6409 * allows readers to hold either lock.
6410 */
6411 lockdep_assert_held(&ar->conf_mutex);
6412 lockdep_assert_held(&ar->data_lock);
6413
Michal Kaziord7bf4b42015-06-03 12:16:54 +02006414 WARN_ON(ctx && vifs);
6415 WARN_ON(vifs && n_vifs != 1);
6416
Michal Kazior500ff9f2015-03-31 10:26:21 +00006417 /* FIXME: Sort of an optimization and a workaround. Peers and vifs are
6418 * on a linked list now. Doing a lookup peer -> vif -> chanctx for each
6419 * ppdu on Rx may reduce performance on low-end systems. It should be
6420 * possible to make tables/hashmaps to speed the lookup up (be vary of
6421 * cpu data cache lines though regarding sizes) but to keep the initial
6422 * implementation simple and less intrusive fallback to the slow lookup
6423 * only for multi-channel cases. Single-channel cases will remain to
6424 * use the old channel derival and thus performance should not be
6425 * affected much.
6426 */
6427 rcu_read_lock();
Michal Kaziord7bf4b42015-06-03 12:16:54 +02006428 if (!ctx && ath10k_mac_num_chanctxs(ar) == 1) {
Michal Kazior500ff9f2015-03-31 10:26:21 +00006429 ieee80211_iter_chan_contexts_atomic(ar->hw,
Kalle Valo617b0f42015-10-05 17:56:35 +03006430 ath10k_mac_get_any_chandef_iter,
6431 &def);
Michal Kaziord7bf4b42015-06-03 12:16:54 +02006432
6433 if (vifs)
6434 def = &vifs[0].new_ctx->def;
6435
Michal Kazior500ff9f2015-03-31 10:26:21 +00006436 ar->rx_channel = def->chan;
Michal Kaziord7bf4b42015-06-03 12:16:54 +02006437 } else if (ctx && ath10k_mac_num_chanctxs(ar) == 0) {
6438 ar->rx_channel = ctx->def.chan;
Michal Kazior500ff9f2015-03-31 10:26:21 +00006439 } else {
6440 ar->rx_channel = NULL;
6441 }
6442 rcu_read_unlock();
6443}
6444
Michal Kazior7be6d1b2015-09-03 10:44:51 +02006445static void
6446ath10k_mac_update_vif_chan(struct ath10k *ar,
6447 struct ieee80211_vif_chanctx_switch *vifs,
6448 int n_vifs)
6449{
6450 struct ath10k_vif *arvif;
6451 int ret;
6452 int i;
6453
6454 lockdep_assert_held(&ar->conf_mutex);
6455
6456 /* First stop monitor interface. Some FW versions crash if there's a
6457 * lone monitor interface.
6458 */
6459 if (ar->monitor_started)
6460 ath10k_monitor_stop(ar);
6461
6462 for (i = 0; i < n_vifs; i++) {
6463 arvif = ath10k_vif_to_arvif(vifs[i].vif);
6464
6465 ath10k_dbg(ar, ATH10K_DBG_MAC,
6466 "mac chanctx switch vdev_id %i freq %hu->%hu width %d->%d\n",
6467 arvif->vdev_id,
6468 vifs[i].old_ctx->def.chan->center_freq,
6469 vifs[i].new_ctx->def.chan->center_freq,
6470 vifs[i].old_ctx->def.width,
6471 vifs[i].new_ctx->def.width);
6472
6473 if (WARN_ON(!arvif->is_started))
6474 continue;
6475
6476 if (WARN_ON(!arvif->is_up))
6477 continue;
6478
6479 ret = ath10k_wmi_vdev_down(ar, arvif->vdev_id);
6480 if (ret) {
6481 ath10k_warn(ar, "failed to down vdev %d: %d\n",
6482 arvif->vdev_id, ret);
6483 continue;
6484 }
6485 }
6486
6487 /* All relevant vdevs are downed and associated channel resources
6488 * should be available for the channel switch now.
6489 */
6490
6491 spin_lock_bh(&ar->data_lock);
6492 ath10k_mac_update_rx_channel(ar, NULL, vifs, n_vifs);
6493 spin_unlock_bh(&ar->data_lock);
6494
6495 for (i = 0; i < n_vifs; i++) {
6496 arvif = ath10k_vif_to_arvif(vifs[i].vif);
6497
6498 if (WARN_ON(!arvif->is_started))
6499 continue;
6500
6501 if (WARN_ON(!arvif->is_up))
6502 continue;
6503
6504 ret = ath10k_mac_setup_bcn_tmpl(arvif);
6505 if (ret)
6506 ath10k_warn(ar, "failed to update bcn tmpl during csa: %d\n",
6507 ret);
6508
6509 ret = ath10k_mac_setup_prb_tmpl(arvif);
6510 if (ret)
6511 ath10k_warn(ar, "failed to update prb tmpl during csa: %d\n",
6512 ret);
6513
6514 ret = ath10k_vdev_restart(arvif, &vifs[i].new_ctx->def);
6515 if (ret) {
6516 ath10k_warn(ar, "failed to restart vdev %d: %d\n",
6517 arvif->vdev_id, ret);
6518 continue;
6519 }
6520
6521 ret = ath10k_wmi_vdev_up(arvif->ar, arvif->vdev_id, arvif->aid,
6522 arvif->bssid);
6523 if (ret) {
6524 ath10k_warn(ar, "failed to bring vdev up %d: %d\n",
6525 arvif->vdev_id, ret);
6526 continue;
6527 }
6528 }
6529
6530 ath10k_monitor_recalc(ar);
6531}
6532
Michal Kazior500ff9f2015-03-31 10:26:21 +00006533static int
6534ath10k_mac_op_add_chanctx(struct ieee80211_hw *hw,
6535 struct ieee80211_chanctx_conf *ctx)
6536{
6537 struct ath10k *ar = hw->priv;
Michal Kazior500ff9f2015-03-31 10:26:21 +00006538
6539 ath10k_dbg(ar, ATH10K_DBG_MAC,
6540 "mac chanctx add freq %hu width %d ptr %p\n",
6541 ctx->def.chan->center_freq, ctx->def.width, ctx);
6542
6543 mutex_lock(&ar->conf_mutex);
6544
6545 spin_lock_bh(&ar->data_lock);
Michal Kaziord7bf4b42015-06-03 12:16:54 +02006546 ath10k_mac_update_rx_channel(ar, ctx, NULL, 0);
Michal Kazior500ff9f2015-03-31 10:26:21 +00006547 spin_unlock_bh(&ar->data_lock);
6548
6549 ath10k_recalc_radar_detection(ar);
6550 ath10k_monitor_recalc(ar);
6551
6552 mutex_unlock(&ar->conf_mutex);
6553
6554 return 0;
6555}
6556
6557static void
6558ath10k_mac_op_remove_chanctx(struct ieee80211_hw *hw,
6559 struct ieee80211_chanctx_conf *ctx)
6560{
6561 struct ath10k *ar = hw->priv;
6562
6563 ath10k_dbg(ar, ATH10K_DBG_MAC,
6564 "mac chanctx remove freq %hu width %d ptr %p\n",
6565 ctx->def.chan->center_freq, ctx->def.width, ctx);
6566
6567 mutex_lock(&ar->conf_mutex);
6568
6569 spin_lock_bh(&ar->data_lock);
Michal Kaziord7bf4b42015-06-03 12:16:54 +02006570 ath10k_mac_update_rx_channel(ar, NULL, NULL, 0);
Michal Kazior500ff9f2015-03-31 10:26:21 +00006571 spin_unlock_bh(&ar->data_lock);
6572
6573 ath10k_recalc_radar_detection(ar);
6574 ath10k_monitor_recalc(ar);
6575
6576 mutex_unlock(&ar->conf_mutex);
6577}
6578
Michal Kazior9713e3d2015-09-03 10:44:52 +02006579struct ath10k_mac_change_chanctx_arg {
6580 struct ieee80211_chanctx_conf *ctx;
6581 struct ieee80211_vif_chanctx_switch *vifs;
6582 int n_vifs;
6583 int next_vif;
6584};
6585
6586static void
6587ath10k_mac_change_chanctx_cnt_iter(void *data, u8 *mac,
6588 struct ieee80211_vif *vif)
6589{
6590 struct ath10k_mac_change_chanctx_arg *arg = data;
6591
6592 if (rcu_access_pointer(vif->chanctx_conf) != arg->ctx)
6593 return;
6594
6595 arg->n_vifs++;
6596}
6597
6598static void
6599ath10k_mac_change_chanctx_fill_iter(void *data, u8 *mac,
6600 struct ieee80211_vif *vif)
6601{
6602 struct ath10k_mac_change_chanctx_arg *arg = data;
6603 struct ieee80211_chanctx_conf *ctx;
6604
6605 ctx = rcu_access_pointer(vif->chanctx_conf);
6606 if (ctx != arg->ctx)
6607 return;
6608
6609 if (WARN_ON(arg->next_vif == arg->n_vifs))
6610 return;
6611
6612 arg->vifs[arg->next_vif].vif = vif;
6613 arg->vifs[arg->next_vif].old_ctx = ctx;
6614 arg->vifs[arg->next_vif].new_ctx = ctx;
6615 arg->next_vif++;
6616}
6617
Michal Kazior500ff9f2015-03-31 10:26:21 +00006618static void
6619ath10k_mac_op_change_chanctx(struct ieee80211_hw *hw,
6620 struct ieee80211_chanctx_conf *ctx,
6621 u32 changed)
6622{
6623 struct ath10k *ar = hw->priv;
Michal Kazior9713e3d2015-09-03 10:44:52 +02006624 struct ath10k_mac_change_chanctx_arg arg = { .ctx = ctx };
Michal Kazior500ff9f2015-03-31 10:26:21 +00006625
6626 mutex_lock(&ar->conf_mutex);
6627
6628 ath10k_dbg(ar, ATH10K_DBG_MAC,
Michal Kazior089ab7a2015-06-03 12:16:55 +02006629 "mac chanctx change freq %hu width %d ptr %p changed %x\n",
6630 ctx->def.chan->center_freq, ctx->def.width, ctx, changed);
Michal Kazior500ff9f2015-03-31 10:26:21 +00006631
6632 /* This shouldn't really happen because channel switching should use
6633 * switch_vif_chanctx().
6634 */
6635 if (WARN_ON(changed & IEEE80211_CHANCTX_CHANGE_CHANNEL))
6636 goto unlock;
6637
Michal Kazior9713e3d2015-09-03 10:44:52 +02006638 if (changed & IEEE80211_CHANCTX_CHANGE_WIDTH) {
6639 ieee80211_iterate_active_interfaces_atomic(
6640 hw,
6641 IEEE80211_IFACE_ITER_NORMAL,
6642 ath10k_mac_change_chanctx_cnt_iter,
6643 &arg);
6644 if (arg.n_vifs == 0)
6645 goto radar;
6646
6647 arg.vifs = kcalloc(arg.n_vifs, sizeof(arg.vifs[0]),
6648 GFP_KERNEL);
6649 if (!arg.vifs)
6650 goto radar;
6651
6652 ieee80211_iterate_active_interfaces_atomic(
6653 hw,
6654 IEEE80211_IFACE_ITER_NORMAL,
6655 ath10k_mac_change_chanctx_fill_iter,
6656 &arg);
6657 ath10k_mac_update_vif_chan(ar, arg.vifs, arg.n_vifs);
6658 kfree(arg.vifs);
6659 }
6660
6661radar:
Michal Kazior500ff9f2015-03-31 10:26:21 +00006662 ath10k_recalc_radar_detection(ar);
6663
6664 /* FIXME: How to configure Rx chains properly? */
6665
6666 /* No other actions are actually necessary. Firmware maintains channel
6667 * definitions per vdev internally and there's no host-side channel
6668 * context abstraction to configure, e.g. channel width.
6669 */
6670
6671unlock:
6672 mutex_unlock(&ar->conf_mutex);
6673}
6674
6675static int
6676ath10k_mac_op_assign_vif_chanctx(struct ieee80211_hw *hw,
6677 struct ieee80211_vif *vif,
6678 struct ieee80211_chanctx_conf *ctx)
6679{
6680 struct ath10k *ar = hw->priv;
Michal Kazior500ff9f2015-03-31 10:26:21 +00006681 struct ath10k_vif *arvif = (void *)vif->drv_priv;
6682 int ret;
6683
6684 mutex_lock(&ar->conf_mutex);
6685
6686 ath10k_dbg(ar, ATH10K_DBG_MAC,
6687 "mac chanctx assign ptr %p vdev_id %i\n",
6688 ctx, arvif->vdev_id);
6689
6690 if (WARN_ON(arvif->is_started)) {
6691 mutex_unlock(&ar->conf_mutex);
6692 return -EBUSY;
6693 }
6694
Michal Kazior089ab7a2015-06-03 12:16:55 +02006695 ret = ath10k_vdev_start(arvif, &ctx->def);
Michal Kazior500ff9f2015-03-31 10:26:21 +00006696 if (ret) {
6697 ath10k_warn(ar, "failed to start vdev %i addr %pM on freq %d: %d\n",
6698 arvif->vdev_id, vif->addr,
Michal Kazior089ab7a2015-06-03 12:16:55 +02006699 ctx->def.chan->center_freq, ret);
Michal Kazior500ff9f2015-03-31 10:26:21 +00006700 goto err;
6701 }
6702
6703 arvif->is_started = true;
6704
Michal Kaziorf23e587e2015-07-09 13:08:37 +02006705 ret = ath10k_mac_vif_setup_ps(arvif);
6706 if (ret) {
6707 ath10k_warn(ar, "failed to update vdev %i ps: %d\n",
6708 arvif->vdev_id, ret);
6709 goto err_stop;
6710 }
6711
Michal Kazior500ff9f2015-03-31 10:26:21 +00006712 if (vif->type == NL80211_IFTYPE_MONITOR) {
6713 ret = ath10k_wmi_vdev_up(ar, arvif->vdev_id, 0, vif->addr);
6714 if (ret) {
6715 ath10k_warn(ar, "failed to up monitor vdev %i: %d\n",
6716 arvif->vdev_id, ret);
6717 goto err_stop;
6718 }
6719
6720 arvif->is_up = true;
6721 }
6722
6723 mutex_unlock(&ar->conf_mutex);
6724 return 0;
6725
6726err_stop:
6727 ath10k_vdev_stop(arvif);
6728 arvif->is_started = false;
Michal Kaziorf23e587e2015-07-09 13:08:37 +02006729 ath10k_mac_vif_setup_ps(arvif);
Michal Kazior500ff9f2015-03-31 10:26:21 +00006730
6731err:
6732 mutex_unlock(&ar->conf_mutex);
6733 return ret;
6734}
6735
6736static void
6737ath10k_mac_op_unassign_vif_chanctx(struct ieee80211_hw *hw,
6738 struct ieee80211_vif *vif,
6739 struct ieee80211_chanctx_conf *ctx)
6740{
6741 struct ath10k *ar = hw->priv;
6742 struct ath10k_vif *arvif = (void *)vif->drv_priv;
6743 int ret;
6744
6745 mutex_lock(&ar->conf_mutex);
6746
6747 ath10k_dbg(ar, ATH10K_DBG_MAC,
6748 "mac chanctx unassign ptr %p vdev_id %i\n",
6749 ctx, arvif->vdev_id);
6750
6751 WARN_ON(!arvif->is_started);
6752
6753 if (vif->type == NL80211_IFTYPE_MONITOR) {
6754 WARN_ON(!arvif->is_up);
6755
6756 ret = ath10k_wmi_vdev_down(ar, arvif->vdev_id);
6757 if (ret)
6758 ath10k_warn(ar, "failed to down monitor vdev %i: %d\n",
6759 arvif->vdev_id, ret);
6760
6761 arvif->is_up = false;
6762 }
6763
6764 ret = ath10k_vdev_stop(arvif);
6765 if (ret)
6766 ath10k_warn(ar, "failed to stop vdev %i: %d\n",
6767 arvif->vdev_id, ret);
6768
6769 arvif->is_started = false;
6770
6771 mutex_unlock(&ar->conf_mutex);
6772}
6773
6774static int
6775ath10k_mac_op_switch_vif_chanctx(struct ieee80211_hw *hw,
6776 struct ieee80211_vif_chanctx_switch *vifs,
6777 int n_vifs,
6778 enum ieee80211_chanctx_switch_mode mode)
6779{
6780 struct ath10k *ar = hw->priv;
Michal Kazior500ff9f2015-03-31 10:26:21 +00006781
6782 mutex_lock(&ar->conf_mutex);
6783
6784 ath10k_dbg(ar, ATH10K_DBG_MAC,
6785 "mac chanctx switch n_vifs %d mode %d\n",
6786 n_vifs, mode);
Michal Kazior7be6d1b2015-09-03 10:44:51 +02006787 ath10k_mac_update_vif_chan(ar, vifs, n_vifs);
Michal Kazior500ff9f2015-03-31 10:26:21 +00006788
6789 mutex_unlock(&ar->conf_mutex);
6790 return 0;
6791}
6792
Kalle Valo5e3dd152013-06-12 20:52:10 +03006793static const struct ieee80211_ops ath10k_ops = {
6794 .tx = ath10k_tx,
6795 .start = ath10k_start,
6796 .stop = ath10k_stop,
6797 .config = ath10k_config,
6798 .add_interface = ath10k_add_interface,
6799 .remove_interface = ath10k_remove_interface,
6800 .configure_filter = ath10k_configure_filter,
6801 .bss_info_changed = ath10k_bss_info_changed,
6802 .hw_scan = ath10k_hw_scan,
6803 .cancel_hw_scan = ath10k_cancel_hw_scan,
6804 .set_key = ath10k_set_key,
SenthilKumar Jegadeesan627613f2015-01-29 13:50:38 +02006805 .set_default_unicast_key = ath10k_set_default_unicast_key,
Kalle Valo5e3dd152013-06-12 20:52:10 +03006806 .sta_state = ath10k_sta_state,
6807 .conf_tx = ath10k_conf_tx,
6808 .remain_on_channel = ath10k_remain_on_channel,
6809 .cancel_remain_on_channel = ath10k_cancel_remain_on_channel,
6810 .set_rts_threshold = ath10k_set_rts_threshold,
Michal Kazior92092fe2015-08-03 11:16:43 +02006811 .set_frag_threshold = ath10k_mac_op_set_frag_threshold,
Kalle Valo5e3dd152013-06-12 20:52:10 +03006812 .flush = ath10k_flush,
6813 .tx_last_beacon = ath10k_tx_last_beacon,
Ben Greear46acf7b2014-05-16 17:15:38 +03006814 .set_antenna = ath10k_set_antenna,
6815 .get_antenna = ath10k_get_antenna,
Eliad Pellercf2c92d2014-11-04 11:43:54 +02006816 .reconfig_complete = ath10k_reconfig_complete,
Michal Kazior2e1dea42013-07-31 10:32:40 +02006817 .get_survey = ath10k_get_survey,
Michal Kazior3ae54222015-03-31 10:49:20 +00006818 .set_bitrate_mask = ath10k_mac_op_set_bitrate_mask,
Michal Kazior9797feb2014-02-14 14:49:48 +01006819 .sta_rc_update = ath10k_sta_rc_update,
Chun-Yeow Yeoh26ebbcc2014-02-25 09:29:54 +02006820 .get_tsf = ath10k_get_tsf,
Michal Kazioraa5b4fb2014-07-23 12:20:33 +02006821 .ampdu_action = ath10k_ampdu_action,
Ben Greear6cddcc72014-09-29 14:41:46 +03006822 .get_et_sset_count = ath10k_debug_get_et_sset_count,
6823 .get_et_stats = ath10k_debug_get_et_stats,
6824 .get_et_strings = ath10k_debug_get_et_strings,
Michal Kazior500ff9f2015-03-31 10:26:21 +00006825 .add_chanctx = ath10k_mac_op_add_chanctx,
6826 .remove_chanctx = ath10k_mac_op_remove_chanctx,
6827 .change_chanctx = ath10k_mac_op_change_chanctx,
6828 .assign_vif_chanctx = ath10k_mac_op_assign_vif_chanctx,
6829 .unassign_vif_chanctx = ath10k_mac_op_unassign_vif_chanctx,
6830 .switch_vif_chanctx = ath10k_mac_op_switch_vif_chanctx,
Kalle Valo43d2a302014-09-10 18:23:30 +03006831
6832 CFG80211_TESTMODE_CMD(ath10k_tm_cmd)
6833
Michal Kazior8cd13ca2013-07-16 09:38:54 +02006834#ifdef CONFIG_PM
Janusz Dziedzic5fd3ac32015-03-23 17:32:53 +02006835 .suspend = ath10k_wow_op_suspend,
6836 .resume = ath10k_wow_op_resume,
Michal Kazior8cd13ca2013-07-16 09:38:54 +02006837#endif
Rajkumar Manoharanf5045982015-01-12 14:07:27 +02006838#ifdef CONFIG_MAC80211_DEBUGFS
6839 .sta_add_debugfs = ath10k_sta_add_debugfs,
6840#endif
Kalle Valo5e3dd152013-06-12 20:52:10 +03006841};
6842
Kalle Valo5e3dd152013-06-12 20:52:10 +03006843#define CHAN2G(_channel, _freq, _flags) { \
6844 .band = IEEE80211_BAND_2GHZ, \
6845 .hw_value = (_channel), \
6846 .center_freq = (_freq), \
6847 .flags = (_flags), \
6848 .max_antenna_gain = 0, \
6849 .max_power = 30, \
6850}
6851
6852#define CHAN5G(_channel, _freq, _flags) { \
6853 .band = IEEE80211_BAND_5GHZ, \
6854 .hw_value = (_channel), \
6855 .center_freq = (_freq), \
6856 .flags = (_flags), \
6857 .max_antenna_gain = 0, \
6858 .max_power = 30, \
6859}
6860
6861static const struct ieee80211_channel ath10k_2ghz_channels[] = {
6862 CHAN2G(1, 2412, 0),
6863 CHAN2G(2, 2417, 0),
6864 CHAN2G(3, 2422, 0),
6865 CHAN2G(4, 2427, 0),
6866 CHAN2G(5, 2432, 0),
6867 CHAN2G(6, 2437, 0),
6868 CHAN2G(7, 2442, 0),
6869 CHAN2G(8, 2447, 0),
6870 CHAN2G(9, 2452, 0),
6871 CHAN2G(10, 2457, 0),
6872 CHAN2G(11, 2462, 0),
6873 CHAN2G(12, 2467, 0),
6874 CHAN2G(13, 2472, 0),
6875 CHAN2G(14, 2484, 0),
6876};
6877
6878static const struct ieee80211_channel ath10k_5ghz_channels[] = {
Michal Kazior429ff562013-06-26 08:54:54 +02006879 CHAN5G(36, 5180, 0),
6880 CHAN5G(40, 5200, 0),
6881 CHAN5G(44, 5220, 0),
6882 CHAN5G(48, 5240, 0),
6883 CHAN5G(52, 5260, 0),
6884 CHAN5G(56, 5280, 0),
6885 CHAN5G(60, 5300, 0),
6886 CHAN5G(64, 5320, 0),
6887 CHAN5G(100, 5500, 0),
6888 CHAN5G(104, 5520, 0),
6889 CHAN5G(108, 5540, 0),
6890 CHAN5G(112, 5560, 0),
6891 CHAN5G(116, 5580, 0),
6892 CHAN5G(120, 5600, 0),
6893 CHAN5G(124, 5620, 0),
6894 CHAN5G(128, 5640, 0),
6895 CHAN5G(132, 5660, 0),
6896 CHAN5G(136, 5680, 0),
6897 CHAN5G(140, 5700, 0),
Peter Oh4a7898f2015-03-18 11:39:18 -07006898 CHAN5G(144, 5720, 0),
Michal Kazior429ff562013-06-26 08:54:54 +02006899 CHAN5G(149, 5745, 0),
6900 CHAN5G(153, 5765, 0),
6901 CHAN5G(157, 5785, 0),
6902 CHAN5G(161, 5805, 0),
6903 CHAN5G(165, 5825, 0),
Kalle Valo5e3dd152013-06-12 20:52:10 +03006904};
6905
Michal Kaziore7b54192014-08-07 11:03:27 +02006906struct ath10k *ath10k_mac_create(size_t priv_size)
Kalle Valo5e3dd152013-06-12 20:52:10 +03006907{
6908 struct ieee80211_hw *hw;
6909 struct ath10k *ar;
6910
Michal Kaziore7b54192014-08-07 11:03:27 +02006911 hw = ieee80211_alloc_hw(sizeof(struct ath10k) + priv_size, &ath10k_ops);
Kalle Valo5e3dd152013-06-12 20:52:10 +03006912 if (!hw)
6913 return NULL;
6914
6915 ar = hw->priv;
6916 ar->hw = hw;
6917
6918 return ar;
6919}
6920
6921void ath10k_mac_destroy(struct ath10k *ar)
6922{
6923 ieee80211_free_hw(ar->hw);
6924}
6925
6926static const struct ieee80211_iface_limit ath10k_if_limits[] = {
6927 {
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05306928 .max = 8,
6929 .types = BIT(NL80211_IFTYPE_STATION)
6930 | BIT(NL80211_IFTYPE_P2P_CLIENT)
Michal Kaziord531cb82013-07-31 10:55:13 +02006931 },
6932 {
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05306933 .max = 3,
6934 .types = BIT(NL80211_IFTYPE_P2P_GO)
Michal Kaziord531cb82013-07-31 10:55:13 +02006935 },
6936 {
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05306937 .max = 1,
6938 .types = BIT(NL80211_IFTYPE_P2P_DEVICE)
Michal Kazior75d2bd42014-12-12 12:41:39 +01006939 },
6940 {
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05306941 .max = 7,
6942 .types = BIT(NL80211_IFTYPE_AP)
Bob Copelandb6c7baf2015-09-09 12:47:36 -04006943#ifdef CONFIG_MAC80211_MESH
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05306944 | BIT(NL80211_IFTYPE_MESH_POINT)
Bob Copelandb6c7baf2015-09-09 12:47:36 -04006945#endif
Michal Kaziord531cb82013-07-31 10:55:13 +02006946 },
Kalle Valo5e3dd152013-06-12 20:52:10 +03006947};
6948
Bartosz Markowskif2595092013-12-10 16:20:39 +01006949static const struct ieee80211_iface_limit ath10k_10x_if_limits[] = {
Marek Puzyniake8a50f82013-11-20 09:59:47 +02006950 {
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05306951 .max = 8,
6952 .types = BIT(NL80211_IFTYPE_AP)
Bob Copelandb6c7baf2015-09-09 12:47:36 -04006953#ifdef CONFIG_MAC80211_MESH
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05306954 | BIT(NL80211_IFTYPE_MESH_POINT)
Bob Copelandb6c7baf2015-09-09 12:47:36 -04006955#endif
Marek Puzyniake8a50f82013-11-20 09:59:47 +02006956 },
Mohammed Shafi Shajakhan78f7aeb2015-11-21 15:24:41 +05306957 {
6958 .max = 1,
6959 .types = BIT(NL80211_IFTYPE_STATION)
6960 },
Marek Puzyniake8a50f82013-11-20 09:59:47 +02006961};
Marek Puzyniake8a50f82013-11-20 09:59:47 +02006962
6963static const struct ieee80211_iface_combination ath10k_if_comb[] = {
6964 {
6965 .limits = ath10k_if_limits,
6966 .n_limits = ARRAY_SIZE(ath10k_if_limits),
6967 .max_interfaces = 8,
6968 .num_different_channels = 1,
6969 .beacon_int_infra_match = true,
6970 },
Bartosz Markowskif2595092013-12-10 16:20:39 +01006971};
6972
6973static const struct ieee80211_iface_combination ath10k_10x_if_comb[] = {
Marek Puzyniake8a50f82013-11-20 09:59:47 +02006974 {
Bartosz Markowskif2595092013-12-10 16:20:39 +01006975 .limits = ath10k_10x_if_limits,
6976 .n_limits = ARRAY_SIZE(ath10k_10x_if_limits),
Marek Puzyniake8a50f82013-11-20 09:59:47 +02006977 .max_interfaces = 8,
6978 .num_different_channels = 1,
6979 .beacon_int_infra_match = true,
Bartosz Markowskif2595092013-12-10 16:20:39 +01006980#ifdef CONFIG_ATH10K_DFS_CERTIFIED
Marek Puzyniake8a50f82013-11-20 09:59:47 +02006981 .radar_detect_widths = BIT(NL80211_CHAN_WIDTH_20_NOHT) |
6982 BIT(NL80211_CHAN_WIDTH_20) |
6983 BIT(NL80211_CHAN_WIDTH_40) |
6984 BIT(NL80211_CHAN_WIDTH_80),
Marek Puzyniake8a50f82013-11-20 09:59:47 +02006985#endif
Bartosz Markowskif2595092013-12-10 16:20:39 +01006986 },
Kalle Valo5e3dd152013-06-12 20:52:10 +03006987};
6988
Michal Kaziorcf327842015-03-31 10:26:25 +00006989static const struct ieee80211_iface_limit ath10k_tlv_if_limit[] = {
6990 {
6991 .max = 2,
Michal Kaziored25b112015-07-09 13:08:39 +02006992 .types = BIT(NL80211_IFTYPE_STATION),
6993 },
6994 {
6995 .max = 2,
6996 .types = BIT(NL80211_IFTYPE_AP) |
Bob Copelandb6c7baf2015-09-09 12:47:36 -04006997#ifdef CONFIG_MAC80211_MESH
6998 BIT(NL80211_IFTYPE_MESH_POINT) |
6999#endif
Michal Kaziorcf327842015-03-31 10:26:25 +00007000 BIT(NL80211_IFTYPE_P2P_CLIENT) |
7001 BIT(NL80211_IFTYPE_P2P_GO),
7002 },
7003 {
7004 .max = 1,
7005 .types = BIT(NL80211_IFTYPE_P2P_DEVICE),
7006 },
7007};
7008
Michal Kaziored25b112015-07-09 13:08:39 +02007009static const struct ieee80211_iface_limit ath10k_tlv_qcs_if_limit[] = {
7010 {
7011 .max = 2,
7012 .types = BIT(NL80211_IFTYPE_STATION),
7013 },
7014 {
7015 .max = 2,
7016 .types = BIT(NL80211_IFTYPE_P2P_CLIENT),
7017 },
7018 {
7019 .max = 1,
7020 .types = BIT(NL80211_IFTYPE_AP) |
Bob Copelandb6c7baf2015-09-09 12:47:36 -04007021#ifdef CONFIG_MAC80211_MESH
7022 BIT(NL80211_IFTYPE_MESH_POINT) |
7023#endif
Michal Kaziored25b112015-07-09 13:08:39 +02007024 BIT(NL80211_IFTYPE_P2P_GO),
7025 },
7026 {
7027 .max = 1,
7028 .types = BIT(NL80211_IFTYPE_P2P_DEVICE),
7029 },
7030};
7031
Michal Kaziorcf327842015-03-31 10:26:25 +00007032static const struct ieee80211_iface_limit ath10k_tlv_if_limit_ibss[] = {
7033 {
7034 .max = 1,
7035 .types = BIT(NL80211_IFTYPE_STATION),
7036 },
7037 {
7038 .max = 1,
7039 .types = BIT(NL80211_IFTYPE_ADHOC),
7040 },
7041};
7042
7043/* FIXME: This is not thouroughly tested. These combinations may over- or
7044 * underestimate hw/fw capabilities.
7045 */
7046static struct ieee80211_iface_combination ath10k_tlv_if_comb[] = {
7047 {
7048 .limits = ath10k_tlv_if_limit,
7049 .num_different_channels = 1,
Michal Kaziored25b112015-07-09 13:08:39 +02007050 .max_interfaces = 4,
Michal Kaziorcf327842015-03-31 10:26:25 +00007051 .n_limits = ARRAY_SIZE(ath10k_tlv_if_limit),
7052 },
7053 {
7054 .limits = ath10k_tlv_if_limit_ibss,
7055 .num_different_channels = 1,
7056 .max_interfaces = 2,
7057 .n_limits = ARRAY_SIZE(ath10k_tlv_if_limit_ibss),
7058 },
7059};
7060
7061static struct ieee80211_iface_combination ath10k_tlv_qcs_if_comb[] = {
7062 {
7063 .limits = ath10k_tlv_if_limit,
Michal Kaziored25b112015-07-09 13:08:39 +02007064 .num_different_channels = 1,
7065 .max_interfaces = 4,
Michal Kaziorcf327842015-03-31 10:26:25 +00007066 .n_limits = ARRAY_SIZE(ath10k_tlv_if_limit),
7067 },
7068 {
Michal Kaziored25b112015-07-09 13:08:39 +02007069 .limits = ath10k_tlv_qcs_if_limit,
7070 .num_different_channels = 2,
7071 .max_interfaces = 4,
7072 .n_limits = ARRAY_SIZE(ath10k_tlv_qcs_if_limit),
7073 },
7074 {
Michal Kaziorcf327842015-03-31 10:26:25 +00007075 .limits = ath10k_tlv_if_limit_ibss,
7076 .num_different_channels = 1,
7077 .max_interfaces = 2,
7078 .n_limits = ARRAY_SIZE(ath10k_tlv_if_limit_ibss),
7079 },
7080};
7081
Raja Manicf36fef2015-06-22 20:22:25 +05307082static const struct ieee80211_iface_limit ath10k_10_4_if_limits[] = {
7083 {
7084 .max = 1,
7085 .types = BIT(NL80211_IFTYPE_STATION),
7086 },
7087 {
7088 .max = 16,
7089 .types = BIT(NL80211_IFTYPE_AP)
Bob Copelandb6c7baf2015-09-09 12:47:36 -04007090#ifdef CONFIG_MAC80211_MESH
7091 | BIT(NL80211_IFTYPE_MESH_POINT)
7092#endif
Raja Manicf36fef2015-06-22 20:22:25 +05307093 },
7094};
7095
7096static const struct ieee80211_iface_combination ath10k_10_4_if_comb[] = {
7097 {
7098 .limits = ath10k_10_4_if_limits,
7099 .n_limits = ARRAY_SIZE(ath10k_10_4_if_limits),
7100 .max_interfaces = 16,
7101 .num_different_channels = 1,
7102 .beacon_int_infra_match = true,
7103#ifdef CONFIG_ATH10K_DFS_CERTIFIED
7104 .radar_detect_widths = BIT(NL80211_CHAN_WIDTH_20_NOHT) |
7105 BIT(NL80211_CHAN_WIDTH_20) |
7106 BIT(NL80211_CHAN_WIDTH_40) |
7107 BIT(NL80211_CHAN_WIDTH_80),
7108#endif
7109 },
7110};
7111
Kalle Valo5e3dd152013-06-12 20:52:10 +03007112static void ath10k_get_arvif_iter(void *data, u8 *mac,
7113 struct ieee80211_vif *vif)
7114{
7115 struct ath10k_vif_iter *arvif_iter = data;
7116 struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
7117
7118 if (arvif->vdev_id == arvif_iter->vdev_id)
7119 arvif_iter->arvif = arvif;
7120}
7121
7122struct ath10k_vif *ath10k_get_arvif(struct ath10k *ar, u32 vdev_id)
7123{
7124 struct ath10k_vif_iter arvif_iter;
7125 u32 flags;
7126
7127 memset(&arvif_iter, 0, sizeof(struct ath10k_vif_iter));
7128 arvif_iter.vdev_id = vdev_id;
7129
7130 flags = IEEE80211_IFACE_ITER_RESUME_ALL;
7131 ieee80211_iterate_active_interfaces_atomic(ar->hw,
7132 flags,
7133 ath10k_get_arvif_iter,
7134 &arvif_iter);
7135 if (!arvif_iter.arvif) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02007136 ath10k_warn(ar, "No VIF found for vdev %d\n", vdev_id);
Kalle Valo5e3dd152013-06-12 20:52:10 +03007137 return NULL;
7138 }
7139
7140 return arvif_iter.arvif;
7141}
7142
7143int ath10k_mac_register(struct ath10k *ar)
7144{
Johannes Berg3cb10942015-01-22 21:38:45 +01007145 static const u32 cipher_suites[] = {
7146 WLAN_CIPHER_SUITE_WEP40,
7147 WLAN_CIPHER_SUITE_WEP104,
7148 WLAN_CIPHER_SUITE_TKIP,
7149 WLAN_CIPHER_SUITE_CCMP,
7150 WLAN_CIPHER_SUITE_AES_CMAC,
7151 };
Kalle Valo5e3dd152013-06-12 20:52:10 +03007152 struct ieee80211_supported_band *band;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007153 void *channels;
7154 int ret;
7155
7156 SET_IEEE80211_PERM_ADDR(ar->hw, ar->mac_addr);
7157
7158 SET_IEEE80211_DEV(ar->hw, ar->dev);
7159
Michal Kaziorc94aa7e2015-03-24 12:38:11 +00007160 BUILD_BUG_ON((ARRAY_SIZE(ath10k_2ghz_channels) +
7161 ARRAY_SIZE(ath10k_5ghz_channels)) !=
7162 ATH10K_NUM_CHANS);
7163
Kalle Valo5e3dd152013-06-12 20:52:10 +03007164 if (ar->phy_capability & WHAL_WLAN_11G_CAPABILITY) {
7165 channels = kmemdup(ath10k_2ghz_channels,
7166 sizeof(ath10k_2ghz_channels),
7167 GFP_KERNEL);
Michal Kaziord6015b22013-07-22 14:13:30 +02007168 if (!channels) {
7169 ret = -ENOMEM;
7170 goto err_free;
7171 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03007172
7173 band = &ar->mac.sbands[IEEE80211_BAND_2GHZ];
7174 band->n_channels = ARRAY_SIZE(ath10k_2ghz_channels);
7175 band->channels = channels;
7176 band->n_bitrates = ath10k_g_rates_size;
7177 band->bitrates = ath10k_g_rates;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007178
7179 ar->hw->wiphy->bands[IEEE80211_BAND_2GHZ] = band;
7180 }
7181
7182 if (ar->phy_capability & WHAL_WLAN_11A_CAPABILITY) {
7183 channels = kmemdup(ath10k_5ghz_channels,
7184 sizeof(ath10k_5ghz_channels),
7185 GFP_KERNEL);
7186 if (!channels) {
Michal Kaziord6015b22013-07-22 14:13:30 +02007187 ret = -ENOMEM;
7188 goto err_free;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007189 }
7190
7191 band = &ar->mac.sbands[IEEE80211_BAND_5GHZ];
7192 band->n_channels = ARRAY_SIZE(ath10k_5ghz_channels);
7193 band->channels = channels;
7194 band->n_bitrates = ath10k_a_rates_size;
7195 band->bitrates = ath10k_a_rates;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007196 ar->hw->wiphy->bands[IEEE80211_BAND_5GHZ] = band;
7197 }
7198
Rajkumar Manoharan5036fe02015-10-27 17:51:14 +05307199 ath10k_mac_setup_ht_vht_cap(ar);
7200
Kalle Valo5e3dd152013-06-12 20:52:10 +03007201 ar->hw->wiphy->interface_modes =
7202 BIT(NL80211_IFTYPE_STATION) |
Bob Copelandb6c7baf2015-09-09 12:47:36 -04007203 BIT(NL80211_IFTYPE_AP) |
7204 BIT(NL80211_IFTYPE_MESH_POINT);
Bartosz Markowskid3541812013-12-10 16:20:40 +01007205
Rajkumar Manoharan166de3f2015-10-27 17:51:11 +05307206 ar->hw->wiphy->available_antennas_rx = ar->cfg_rx_chainmask;
7207 ar->hw->wiphy->available_antennas_tx = ar->cfg_tx_chainmask;
Ben Greear46acf7b2014-05-16 17:15:38 +03007208
Bartosz Markowskid3541812013-12-10 16:20:40 +01007209 if (!test_bit(ATH10K_FW_FEATURE_NO_P2P, ar->fw_features))
7210 ar->hw->wiphy->interface_modes |=
Michal Kazior75d2bd42014-12-12 12:41:39 +01007211 BIT(NL80211_IFTYPE_P2P_DEVICE) |
Bartosz Markowskid3541812013-12-10 16:20:40 +01007212 BIT(NL80211_IFTYPE_P2P_CLIENT) |
7213 BIT(NL80211_IFTYPE_P2P_GO);
Kalle Valo5e3dd152013-06-12 20:52:10 +03007214
Johannes Berg30686bf2015-06-02 21:39:54 +02007215 ieee80211_hw_set(ar->hw, SIGNAL_DBM);
7216 ieee80211_hw_set(ar->hw, SUPPORTS_PS);
7217 ieee80211_hw_set(ar->hw, SUPPORTS_DYNAMIC_PS);
7218 ieee80211_hw_set(ar->hw, MFP_CAPABLE);
7219 ieee80211_hw_set(ar->hw, REPORTS_TX_ACK_STATUS);
7220 ieee80211_hw_set(ar->hw, HAS_RATE_CONTROL);
7221 ieee80211_hw_set(ar->hw, AP_LINK_PS);
7222 ieee80211_hw_set(ar->hw, SPECTRUM_MGMT);
Johannes Berg30686bf2015-06-02 21:39:54 +02007223 ieee80211_hw_set(ar->hw, SUPPORT_FAST_XMIT);
7224 ieee80211_hw_set(ar->hw, CONNECTION_MONITOR);
7225 ieee80211_hw_set(ar->hw, SUPPORTS_PER_STA_GTK);
7226 ieee80211_hw_set(ar->hw, WANT_MONITOR_VIF);
7227 ieee80211_hw_set(ar->hw, CHANCTX_STA_CSA);
7228 ieee80211_hw_set(ar->hw, QUEUE_CONTROL);
Kalle Valo5e3dd152013-06-12 20:52:10 +03007229
David Liuccec9032015-07-24 20:25:32 +03007230 if (!test_bit(ATH10K_FLAG_RAW_MODE, &ar->dev_flags))
7231 ieee80211_hw_set(ar->hw, SW_CRYPTO_CONTROL);
7232
Eliad Peller0d8614b2014-09-10 14:07:36 +03007233 ar->hw->wiphy->features |= NL80211_FEATURE_STATIC_SMPS;
Janusz Dziedzic0cd9bc12015-04-10 13:23:23 +00007234 ar->hw->wiphy->flags |= WIPHY_FLAG_IBSS_RSN;
Eliad Peller0d8614b2014-09-10 14:07:36 +03007235
Kalle Valo5e3dd152013-06-12 20:52:10 +03007236 if (ar->ht_cap_info & WMI_HT_CAP_DYNAMIC_SMPS)
Eliad Peller0d8614b2014-09-10 14:07:36 +03007237 ar->hw->wiphy->features |= NL80211_FEATURE_DYNAMIC_SMPS;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007238
7239 if (ar->ht_cap_info & WMI_HT_CAP_ENABLED) {
Johannes Berg30686bf2015-06-02 21:39:54 +02007240 ieee80211_hw_set(ar->hw, AMPDU_AGGREGATION);
7241 ieee80211_hw_set(ar->hw, TX_AMPDU_SETUP_IN_HW);
Kalle Valo5e3dd152013-06-12 20:52:10 +03007242 }
7243
7244 ar->hw->wiphy->max_scan_ssids = WLAN_SCAN_PARAMS_MAX_SSID;
7245 ar->hw->wiphy->max_scan_ie_len = WLAN_SCAN_PARAMS_MAX_IE_LEN;
7246
7247 ar->hw->vif_data_size = sizeof(struct ath10k_vif);
Michal Kazior9797feb2014-02-14 14:49:48 +01007248 ar->hw->sta_data_size = sizeof(struct ath10k_sta);
Kalle Valo5e3dd152013-06-12 20:52:10 +03007249
Kalle Valo5e3dd152013-06-12 20:52:10 +03007250 ar->hw->max_listen_interval = ATH10K_MAX_HW_LISTEN_INTERVAL;
7251
Michal Kaziorfbb8f1b2015-01-13 16:30:12 +02007252 if (test_bit(WMI_SERVICE_BEACON_OFFLOAD, ar->wmi.svc_map)) {
7253 ar->hw->wiphy->flags |= WIPHY_FLAG_AP_PROBE_RESP_OFFLOAD;
7254
7255 /* Firmware delivers WPS/P2P Probe Requests frames to driver so
7256 * that userspace (e.g. wpa_supplicant/hostapd) can generate
7257 * correct Probe Responses. This is more of a hack advert..
7258 */
7259 ar->hw->wiphy->probe_resp_offload |=
7260 NL80211_PROBE_RESP_OFFLOAD_SUPPORT_WPS |
7261 NL80211_PROBE_RESP_OFFLOAD_SUPPORT_WPS2 |
7262 NL80211_PROBE_RESP_OFFLOAD_SUPPORT_P2P;
7263 }
7264
Marek Puzyniak75d85fd2015-03-30 09:51:53 +03007265 if (test_bit(WMI_SERVICE_TDLS, ar->wmi.svc_map))
7266 ar->hw->wiphy->flags |= WIPHY_FLAG_SUPPORTS_TDLS;
7267
Kalle Valo5e3dd152013-06-12 20:52:10 +03007268 ar->hw->wiphy->flags |= WIPHY_FLAG_HAS_REMAIN_ON_CHANNEL;
Michal Kaziorc2df44b2014-01-23 11:38:26 +01007269 ar->hw->wiphy->flags |= WIPHY_FLAG_HAS_CHANNEL_SWITCH;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007270 ar->hw->wiphy->max_remain_on_channel_duration = 5000;
7271
7272 ar->hw->wiphy->flags |= WIPHY_FLAG_AP_UAPSD;
Rajkumar Manoharan78157a12014-11-17 16:44:15 +02007273 ar->hw->wiphy->features |= NL80211_FEATURE_AP_MODE_CHAN_WIDTH_CHANGE;
7274
Janusz.Dziedzic@tieto.com37a0b392015-03-12 13:11:41 +01007275 ar->hw->wiphy->max_ap_assoc_sta = ar->max_num_stations;
7276
Janusz Dziedzic5fd3ac32015-03-23 17:32:53 +02007277 ret = ath10k_wow_init(ar);
7278 if (ret) {
7279 ath10k_warn(ar, "failed to init wow: %d\n", ret);
7280 goto err_free;
7281 }
7282
Janusz Dziedzicc7025342015-06-15 14:46:41 +03007283 wiphy_ext_feature_set(ar->hw->wiphy, NL80211_EXT_FEATURE_VHT_IBSS);
7284
Kalle Valo5e3dd152013-06-12 20:52:10 +03007285 /*
7286 * on LL hardware queues are managed entirely by the FW
7287 * so we only advertise to mac we can do the queues thing
7288 */
Michal Kazior96d828d2015-03-31 10:26:23 +00007289 ar->hw->queues = IEEE80211_MAX_QUEUES;
7290
7291 /* vdev_ids are used as hw queue numbers. Make sure offchan tx queue is
7292 * something that vdev_ids can't reach so that we don't stop the queue
7293 * accidentally.
7294 */
7295 ar->hw->offchannel_tx_hw_queue = IEEE80211_MAX_QUEUES - 1;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007296
Kalle Valo5cc7caf2014-12-17 12:20:54 +02007297 switch (ar->wmi.op_version) {
7298 case ATH10K_FW_WMI_OP_VERSION_MAIN:
Bartosz Markowskif2595092013-12-10 16:20:39 +01007299 ar->hw->wiphy->iface_combinations = ath10k_if_comb;
7300 ar->hw->wiphy->n_iface_combinations =
7301 ARRAY_SIZE(ath10k_if_comb);
Michal Kaziorcf850d12014-07-24 20:07:00 +03007302 ar->hw->wiphy->interface_modes |= BIT(NL80211_IFTYPE_ADHOC);
Kalle Valo5cc7caf2014-12-17 12:20:54 +02007303 break;
Michal Kaziorcf327842015-03-31 10:26:25 +00007304 case ATH10K_FW_WMI_OP_VERSION_TLV:
7305 if (test_bit(WMI_SERVICE_ADAPTIVE_OCS, ar->wmi.svc_map)) {
7306 ar->hw->wiphy->iface_combinations =
7307 ath10k_tlv_qcs_if_comb;
7308 ar->hw->wiphy->n_iface_combinations =
7309 ARRAY_SIZE(ath10k_tlv_qcs_if_comb);
7310 } else {
7311 ar->hw->wiphy->iface_combinations = ath10k_tlv_if_comb;
7312 ar->hw->wiphy->n_iface_combinations =
7313 ARRAY_SIZE(ath10k_tlv_if_comb);
7314 }
7315 ar->hw->wiphy->interface_modes |= BIT(NL80211_IFTYPE_ADHOC);
7316 break;
Kalle Valo5cc7caf2014-12-17 12:20:54 +02007317 case ATH10K_FW_WMI_OP_VERSION_10_1:
7318 case ATH10K_FW_WMI_OP_VERSION_10_2:
Rajkumar Manoharan4a16fbe2014-12-17 12:21:12 +02007319 case ATH10K_FW_WMI_OP_VERSION_10_2_4:
Kalle Valo5cc7caf2014-12-17 12:20:54 +02007320 ar->hw->wiphy->iface_combinations = ath10k_10x_if_comb;
7321 ar->hw->wiphy->n_iface_combinations =
7322 ARRAY_SIZE(ath10k_10x_if_comb);
7323 break;
Raja Mani9bd21322015-06-22 20:10:09 +05307324 case ATH10K_FW_WMI_OP_VERSION_10_4:
Raja Manicf36fef2015-06-22 20:22:25 +05307325 ar->hw->wiphy->iface_combinations = ath10k_10_4_if_comb;
7326 ar->hw->wiphy->n_iface_combinations =
7327 ARRAY_SIZE(ath10k_10_4_if_comb);
Raja Mani9bd21322015-06-22 20:10:09 +05307328 break;
Kalle Valo5cc7caf2014-12-17 12:20:54 +02007329 case ATH10K_FW_WMI_OP_VERSION_UNSET:
7330 case ATH10K_FW_WMI_OP_VERSION_MAX:
7331 WARN_ON(1);
7332 ret = -EINVAL;
7333 goto err_free;
Bartosz Markowskif2595092013-12-10 16:20:39 +01007334 }
Kalle Valo5e3dd152013-06-12 20:52:10 +03007335
David Liuccec9032015-07-24 20:25:32 +03007336 if (!test_bit(ATH10K_FLAG_RAW_MODE, &ar->dev_flags))
7337 ar->hw->netdev_features = NETIF_F_HW_CSUM;
Michal Kazior7c199992013-07-31 10:47:57 +02007338
Janusz Dziedzic9702c682013-11-20 09:59:41 +02007339 if (config_enabled(CONFIG_ATH10K_DFS_CERTIFIED)) {
7340 /* Init ath dfs pattern detector */
7341 ar->ath_common.debug_mask = ATH_DBG_DFS;
7342 ar->dfs_detector = dfs_pattern_detector_init(&ar->ath_common,
7343 NL80211_DFS_UNSET);
7344
7345 if (!ar->dfs_detector)
Michal Kazior7aa7a722014-08-25 12:09:38 +02007346 ath10k_warn(ar, "failed to initialise DFS pattern detector\n");
Janusz Dziedzic9702c682013-11-20 09:59:41 +02007347 }
7348
Kalle Valo5e3dd152013-06-12 20:52:10 +03007349 ret = ath_regd_init(&ar->ath_common.regulatory, ar->hw->wiphy,
7350 ath10k_reg_notifier);
7351 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02007352 ath10k_err(ar, "failed to initialise regulatory: %i\n", ret);
Jeff Johnson0e339442015-10-08 09:15:53 -07007353 goto err_dfs_detector_exit;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007354 }
7355
Johannes Berg3cb10942015-01-22 21:38:45 +01007356 ar->hw->wiphy->cipher_suites = cipher_suites;
7357 ar->hw->wiphy->n_cipher_suites = ARRAY_SIZE(cipher_suites);
7358
Kalle Valo5e3dd152013-06-12 20:52:10 +03007359 ret = ieee80211_register_hw(ar->hw);
7360 if (ret) {
Michal Kazior7aa7a722014-08-25 12:09:38 +02007361 ath10k_err(ar, "failed to register ieee80211: %d\n", ret);
Jeff Johnson0e339442015-10-08 09:15:53 -07007362 goto err_dfs_detector_exit;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007363 }
7364
7365 if (!ath_is_world_regd(&ar->ath_common.regulatory)) {
7366 ret = regulatory_hint(ar->hw->wiphy,
7367 ar->ath_common.regulatory.alpha2);
7368 if (ret)
Michal Kaziord6015b22013-07-22 14:13:30 +02007369 goto err_unregister;
Kalle Valo5e3dd152013-06-12 20:52:10 +03007370 }
7371
7372 return 0;
Michal Kaziord6015b22013-07-22 14:13:30 +02007373
7374err_unregister:
Kalle Valo5e3dd152013-06-12 20:52:10 +03007375 ieee80211_unregister_hw(ar->hw);
Jeff Johnson0e339442015-10-08 09:15:53 -07007376
7377err_dfs_detector_exit:
7378 if (config_enabled(CONFIG_ATH10K_DFS_CERTIFIED) && ar->dfs_detector)
7379 ar->dfs_detector->exit(ar->dfs_detector);
7380
Michal Kaziord6015b22013-07-22 14:13:30 +02007381err_free:
7382 kfree(ar->mac.sbands[IEEE80211_BAND_2GHZ].channels);
7383 kfree(ar->mac.sbands[IEEE80211_BAND_5GHZ].channels);
7384
Jeff Johnson0e339442015-10-08 09:15:53 -07007385 SET_IEEE80211_DEV(ar->hw, NULL);
Kalle Valo5e3dd152013-06-12 20:52:10 +03007386 return ret;
7387}
7388
7389void ath10k_mac_unregister(struct ath10k *ar)
7390{
7391 ieee80211_unregister_hw(ar->hw);
7392
Janusz Dziedzic9702c682013-11-20 09:59:41 +02007393 if (config_enabled(CONFIG_ATH10K_DFS_CERTIFIED) && ar->dfs_detector)
7394 ar->dfs_detector->exit(ar->dfs_detector);
7395
Kalle Valo5e3dd152013-06-12 20:52:10 +03007396 kfree(ar->mac.sbands[IEEE80211_BAND_2GHZ].channels);
7397 kfree(ar->mac.sbands[IEEE80211_BAND_5GHZ].channels);
7398
7399 SET_IEEE80211_DEV(ar->hw, NULL);
7400}