xref: /openbmc/linux/drivers/net/wireless/ath/ath11k/mac.c (revision abe9af53)
1 // SPDX-License-Identifier: BSD-3-Clause-Clear
2 /*
3  * Copyright (c) 2018-2019 The Linux Foundation. All rights reserved.
4  */
5 
6 #include <net/mac80211.h>
7 #include <linux/etherdevice.h>
8 #include "mac.h"
9 #include "core.h"
10 #include "debug.h"
11 #include "wmi.h"
12 #include "hw.h"
13 #include "dp_tx.h"
14 #include "dp_rx.h"
15 #include "testmode.h"
16 #include "peer.h"
17 #include "debugfs_sta.h"
18 
19 #define CHAN2G(_channel, _freq, _flags) { \
20 	.band                   = NL80211_BAND_2GHZ, \
21 	.hw_value               = (_channel), \
22 	.center_freq            = (_freq), \
23 	.flags                  = (_flags), \
24 	.max_antenna_gain       = 0, \
25 	.max_power              = 30, \
26 }
27 
28 #define CHAN5G(_channel, _freq, _flags) { \
29 	.band                   = NL80211_BAND_5GHZ, \
30 	.hw_value               = (_channel), \
31 	.center_freq            = (_freq), \
32 	.flags                  = (_flags), \
33 	.max_antenna_gain       = 0, \
34 	.max_power              = 30, \
35 }
36 
37 #define CHAN6G(_channel, _freq, _flags) { \
38 	.band                   = NL80211_BAND_6GHZ, \
39 	.hw_value               = (_channel), \
40 	.center_freq            = (_freq), \
41 	.flags                  = (_flags), \
42 	.max_antenna_gain       = 0, \
43 	.max_power              = 30, \
44 }
45 
46 static const struct ieee80211_channel ath11k_2ghz_channels[] = {
47 	CHAN2G(1, 2412, 0),
48 	CHAN2G(2, 2417, 0),
49 	CHAN2G(3, 2422, 0),
50 	CHAN2G(4, 2427, 0),
51 	CHAN2G(5, 2432, 0),
52 	CHAN2G(6, 2437, 0),
53 	CHAN2G(7, 2442, 0),
54 	CHAN2G(8, 2447, 0),
55 	CHAN2G(9, 2452, 0),
56 	CHAN2G(10, 2457, 0),
57 	CHAN2G(11, 2462, 0),
58 	CHAN2G(12, 2467, 0),
59 	CHAN2G(13, 2472, 0),
60 	CHAN2G(14, 2484, 0),
61 };
62 
63 static const struct ieee80211_channel ath11k_5ghz_channels[] = {
64 	CHAN5G(36, 5180, 0),
65 	CHAN5G(40, 5200, 0),
66 	CHAN5G(44, 5220, 0),
67 	CHAN5G(48, 5240, 0),
68 	CHAN5G(52, 5260, 0),
69 	CHAN5G(56, 5280, 0),
70 	CHAN5G(60, 5300, 0),
71 	CHAN5G(64, 5320, 0),
72 	CHAN5G(100, 5500, 0),
73 	CHAN5G(104, 5520, 0),
74 	CHAN5G(108, 5540, 0),
75 	CHAN5G(112, 5560, 0),
76 	CHAN5G(116, 5580, 0),
77 	CHAN5G(120, 5600, 0),
78 	CHAN5G(124, 5620, 0),
79 	CHAN5G(128, 5640, 0),
80 	CHAN5G(132, 5660, 0),
81 	CHAN5G(136, 5680, 0),
82 	CHAN5G(140, 5700, 0),
83 	CHAN5G(144, 5720, 0),
84 	CHAN5G(149, 5745, 0),
85 	CHAN5G(153, 5765, 0),
86 	CHAN5G(157, 5785, 0),
87 	CHAN5G(161, 5805, 0),
88 	CHAN5G(165, 5825, 0),
89 	CHAN5G(169, 5845, 0),
90 	CHAN5G(173, 5865, 0),
91 };
92 
93 static const struct ieee80211_channel ath11k_6ghz_channels[] = {
94 	CHAN6G(1, 5955, 0),
95 	CHAN6G(5, 5975, 0),
96 	CHAN6G(9, 5995, 0),
97 	CHAN6G(13, 6015, 0),
98 	CHAN6G(17, 6035, 0),
99 	CHAN6G(21, 6055, 0),
100 	CHAN6G(25, 6075, 0),
101 	CHAN6G(29, 6095, 0),
102 	CHAN6G(33, 6115, 0),
103 	CHAN6G(37, 6135, 0),
104 	CHAN6G(41, 6155, 0),
105 	CHAN6G(45, 6175, 0),
106 	CHAN6G(49, 6195, 0),
107 	CHAN6G(53, 6215, 0),
108 	CHAN6G(57, 6235, 0),
109 	CHAN6G(61, 6255, 0),
110 	CHAN6G(65, 6275, 0),
111 	CHAN6G(69, 6295, 0),
112 	CHAN6G(73, 6315, 0),
113 	CHAN6G(77, 6335, 0),
114 	CHAN6G(81, 6355, 0),
115 	CHAN6G(85, 6375, 0),
116 	CHAN6G(89, 6395, 0),
117 	CHAN6G(93, 6415, 0),
118 	CHAN6G(97, 6435, 0),
119 	CHAN6G(101, 6455, 0),
120 	CHAN6G(105, 6475, 0),
121 	CHAN6G(109, 6495, 0),
122 	CHAN6G(113, 6515, 0),
123 	CHAN6G(117, 6535, 0),
124 	CHAN6G(121, 6555, 0),
125 	CHAN6G(125, 6575, 0),
126 	CHAN6G(129, 6595, 0),
127 	CHAN6G(133, 6615, 0),
128 	CHAN6G(137, 6635, 0),
129 	CHAN6G(141, 6655, 0),
130 	CHAN6G(145, 6675, 0),
131 	CHAN6G(149, 6695, 0),
132 	CHAN6G(153, 6715, 0),
133 	CHAN6G(157, 6735, 0),
134 	CHAN6G(161, 6755, 0),
135 	CHAN6G(165, 6775, 0),
136 	CHAN6G(169, 6795, 0),
137 	CHAN6G(173, 6815, 0),
138 	CHAN6G(177, 6835, 0),
139 	CHAN6G(181, 6855, 0),
140 	CHAN6G(185, 6875, 0),
141 	CHAN6G(189, 6895, 0),
142 	CHAN6G(193, 6915, 0),
143 	CHAN6G(197, 6935, 0),
144 	CHAN6G(201, 6955, 0),
145 	CHAN6G(205, 6975, 0),
146 	CHAN6G(209, 6995, 0),
147 	CHAN6G(213, 7015, 0),
148 	CHAN6G(217, 7035, 0),
149 	CHAN6G(221, 7055, 0),
150 	CHAN6G(225, 7075, 0),
151 	CHAN6G(229, 7095, 0),
152 	CHAN6G(233, 7115, 0),
153 };
154 
155 static struct ieee80211_rate ath11k_legacy_rates[] = {
156 	{ .bitrate = 10,
157 	  .hw_value = ATH11K_HW_RATE_CCK_LP_1M },
158 	{ .bitrate = 20,
159 	  .hw_value = ATH11K_HW_RATE_CCK_LP_2M,
160 	  .hw_value_short = ATH11K_HW_RATE_CCK_SP_2M,
161 	  .flags = IEEE80211_RATE_SHORT_PREAMBLE },
162 	{ .bitrate = 55,
163 	  .hw_value = ATH11K_HW_RATE_CCK_LP_5_5M,
164 	  .hw_value_short = ATH11K_HW_RATE_CCK_SP_5_5M,
165 	  .flags = IEEE80211_RATE_SHORT_PREAMBLE },
166 	{ .bitrate = 110,
167 	  .hw_value = ATH11K_HW_RATE_CCK_LP_11M,
168 	  .hw_value_short = ATH11K_HW_RATE_CCK_SP_11M,
169 	  .flags = IEEE80211_RATE_SHORT_PREAMBLE },
170 
171 	{ .bitrate = 60, .hw_value = ATH11K_HW_RATE_OFDM_6M },
172 	{ .bitrate = 90, .hw_value = ATH11K_HW_RATE_OFDM_9M },
173 	{ .bitrate = 120, .hw_value = ATH11K_HW_RATE_OFDM_12M },
174 	{ .bitrate = 180, .hw_value = ATH11K_HW_RATE_OFDM_18M },
175 	{ .bitrate = 240, .hw_value = ATH11K_HW_RATE_OFDM_24M },
176 	{ .bitrate = 360, .hw_value = ATH11K_HW_RATE_OFDM_36M },
177 	{ .bitrate = 480, .hw_value = ATH11K_HW_RATE_OFDM_48M },
178 	{ .bitrate = 540, .hw_value = ATH11K_HW_RATE_OFDM_54M },
179 };
180 
181 static const int
182 ath11k_phymodes[NUM_NL80211_BANDS][ATH11K_CHAN_WIDTH_NUM] = {
183 	[NL80211_BAND_2GHZ] = {
184 			[NL80211_CHAN_WIDTH_5] = MODE_UNKNOWN,
185 			[NL80211_CHAN_WIDTH_10] = MODE_UNKNOWN,
186 			[NL80211_CHAN_WIDTH_20_NOHT] = MODE_11AX_HE20_2G,
187 			[NL80211_CHAN_WIDTH_20] = MODE_11AX_HE20_2G,
188 			[NL80211_CHAN_WIDTH_40] = MODE_11AX_HE40_2G,
189 			[NL80211_CHAN_WIDTH_80] = MODE_11AX_HE80_2G,
190 			[NL80211_CHAN_WIDTH_80P80] = MODE_UNKNOWN,
191 			[NL80211_CHAN_WIDTH_160] = MODE_UNKNOWN,
192 	},
193 	[NL80211_BAND_5GHZ] = {
194 			[NL80211_CHAN_WIDTH_5] = MODE_UNKNOWN,
195 			[NL80211_CHAN_WIDTH_10] = MODE_UNKNOWN,
196 			[NL80211_CHAN_WIDTH_20_NOHT] = MODE_11AX_HE20,
197 			[NL80211_CHAN_WIDTH_20] = MODE_11AX_HE20,
198 			[NL80211_CHAN_WIDTH_40] = MODE_11AX_HE40,
199 			[NL80211_CHAN_WIDTH_80] = MODE_11AX_HE80,
200 			[NL80211_CHAN_WIDTH_160] = MODE_11AX_HE160,
201 			[NL80211_CHAN_WIDTH_80P80] = MODE_11AX_HE80_80,
202 	},
203 	[NL80211_BAND_6GHZ] = {
204 			[NL80211_CHAN_WIDTH_5] = MODE_UNKNOWN,
205 			[NL80211_CHAN_WIDTH_10] = MODE_UNKNOWN,
206 			[NL80211_CHAN_WIDTH_20_NOHT] = MODE_11AX_HE20,
207 			[NL80211_CHAN_WIDTH_20] = MODE_11AX_HE20,
208 			[NL80211_CHAN_WIDTH_40] = MODE_11AX_HE40,
209 			[NL80211_CHAN_WIDTH_80] = MODE_11AX_HE80,
210 			[NL80211_CHAN_WIDTH_160] = MODE_11AX_HE160,
211 			[NL80211_CHAN_WIDTH_80P80] = MODE_11AX_HE80_80,
212 	},
213 
214 };
215 
216 const struct htt_rx_ring_tlv_filter ath11k_mac_mon_status_filter_default = {
217 	.rx_filter = HTT_RX_FILTER_TLV_FLAGS_MPDU_START |
218 		     HTT_RX_FILTER_TLV_FLAGS_PPDU_END |
219 		     HTT_RX_FILTER_TLV_FLAGS_PPDU_END_STATUS_DONE,
220 	.pkt_filter_flags0 = HTT_RX_FP_MGMT_FILTER_FLAGS0,
221 	.pkt_filter_flags1 = HTT_RX_FP_MGMT_FILTER_FLAGS1,
222 	.pkt_filter_flags2 = HTT_RX_FP_CTRL_FILTER_FLASG2,
223 	.pkt_filter_flags3 = HTT_RX_FP_DATA_FILTER_FLASG3 |
224 			     HTT_RX_FP_CTRL_FILTER_FLASG3
225 };
226 
227 #define ATH11K_MAC_FIRST_OFDM_RATE_IDX 4
228 #define ath11k_g_rates ath11k_legacy_rates
229 #define ath11k_g_rates_size (ARRAY_SIZE(ath11k_legacy_rates))
230 #define ath11k_a_rates (ath11k_legacy_rates + 4)
231 #define ath11k_a_rates_size (ARRAY_SIZE(ath11k_legacy_rates) - 4)
232 
233 #define ATH11K_MAC_SCAN_TIMEOUT_MSECS 200 /* in msecs */
234 
235 static const u32 ath11k_smps_map[] = {
236 	[WLAN_HT_CAP_SM_PS_STATIC] = WMI_PEER_SMPS_STATIC,
237 	[WLAN_HT_CAP_SM_PS_DYNAMIC] = WMI_PEER_SMPS_DYNAMIC,
238 	[WLAN_HT_CAP_SM_PS_INVALID] = WMI_PEER_SMPS_PS_NONE,
239 	[WLAN_HT_CAP_SM_PS_DISABLED] = WMI_PEER_SMPS_PS_NONE,
240 };
241 
242 static int ath11k_start_vdev_delay(struct ieee80211_hw *hw,
243 				   struct ieee80211_vif *vif);
244 
245 u8 ath11k_mac_bw_to_mac80211_bw(u8 bw)
246 {
247 	u8 ret = 0;
248 
249 	switch (bw) {
250 	case ATH11K_BW_20:
251 		ret = RATE_INFO_BW_20;
252 		break;
253 	case ATH11K_BW_40:
254 		ret = RATE_INFO_BW_40;
255 		break;
256 	case ATH11K_BW_80:
257 		ret = RATE_INFO_BW_80;
258 		break;
259 	case ATH11K_BW_160:
260 		ret = RATE_INFO_BW_160;
261 		break;
262 	}
263 
264 	return ret;
265 }
266 
267 enum ath11k_supported_bw ath11k_mac_mac80211_bw_to_ath11k_bw(enum rate_info_bw bw)
268 {
269 	switch (bw) {
270 	case RATE_INFO_BW_20:
271 		return ATH11K_BW_20;
272 	case RATE_INFO_BW_40:
273 		return ATH11K_BW_40;
274 	case RATE_INFO_BW_80:
275 		return ATH11K_BW_80;
276 	case RATE_INFO_BW_160:
277 		return ATH11K_BW_160;
278 	default:
279 		return ATH11K_BW_20;
280 	}
281 }
282 
283 int ath11k_mac_hw_ratecode_to_legacy_rate(u8 hw_rc, u8 preamble, u8 *rateidx,
284 					  u16 *rate)
285 {
286 	/* As default, it is OFDM rates */
287 	int i = ATH11K_MAC_FIRST_OFDM_RATE_IDX;
288 	int max_rates_idx = ath11k_g_rates_size;
289 
290 	if (preamble == WMI_RATE_PREAMBLE_CCK) {
291 		hw_rc &= ~ATH11k_HW_RATECODE_CCK_SHORT_PREAM_MASK;
292 		i = 0;
293 		max_rates_idx = ATH11K_MAC_FIRST_OFDM_RATE_IDX;
294 	}
295 
296 	while (i < max_rates_idx) {
297 		if (hw_rc == ath11k_legacy_rates[i].hw_value) {
298 			*rateidx = i;
299 			*rate = ath11k_legacy_rates[i].bitrate;
300 			return 0;
301 		}
302 		i++;
303 	}
304 
305 	return -EINVAL;
306 }
307 
308 static int get_num_chains(u32 mask)
309 {
310 	int num_chains = 0;
311 
312 	while (mask) {
313 		if (mask & BIT(0))
314 			num_chains++;
315 		mask >>= 1;
316 	}
317 
318 	return num_chains;
319 }
320 
321 u8 ath11k_mac_bitrate_to_idx(const struct ieee80211_supported_band *sband,
322 			     u32 bitrate)
323 {
324 	int i;
325 
326 	for (i = 0; i < sband->n_bitrates; i++)
327 		if (sband->bitrates[i].bitrate == bitrate)
328 			return i;
329 
330 	return 0;
331 }
332 
333 static u32
334 ath11k_mac_max_ht_nss(const u8 ht_mcs_mask[IEEE80211_HT_MCS_MASK_LEN])
335 {
336 	int nss;
337 
338 	for (nss = IEEE80211_HT_MCS_MASK_LEN - 1; nss >= 0; nss--)
339 		if (ht_mcs_mask[nss])
340 			return nss + 1;
341 
342 	return 1;
343 }
344 
345 static u32
346 ath11k_mac_max_vht_nss(const u16 vht_mcs_mask[NL80211_VHT_NSS_MAX])
347 {
348 	int nss;
349 
350 	for (nss = NL80211_VHT_NSS_MAX - 1; nss >= 0; nss--)
351 		if (vht_mcs_mask[nss])
352 			return nss + 1;
353 
354 	return 1;
355 }
356 
357 static u8 ath11k_parse_mpdudensity(u8 mpdudensity)
358 {
359 /* 802.11n D2.0 defined values for "Minimum MPDU Start Spacing":
360  *   0 for no restriction
361  *   1 for 1/4 us
362  *   2 for 1/2 us
363  *   3 for 1 us
364  *   4 for 2 us
365  *   5 for 4 us
366  *   6 for 8 us
367  *   7 for 16 us
368  */
369 	switch (mpdudensity) {
370 	case 0:
371 		return 0;
372 	case 1:
373 	case 2:
374 	case 3:
375 	/* Our lower layer calculations limit our precision to
376 	 * 1 microsecond
377 	 */
378 		return 1;
379 	case 4:
380 		return 2;
381 	case 5:
382 		return 4;
383 	case 6:
384 		return 8;
385 	case 7:
386 		return 16;
387 	default:
388 		return 0;
389 	}
390 }
391 
392 static int ath11k_mac_vif_chan(struct ieee80211_vif *vif,
393 			       struct cfg80211_chan_def *def)
394 {
395 	struct ieee80211_chanctx_conf *conf;
396 
397 	rcu_read_lock();
398 	conf = rcu_dereference(vif->chanctx_conf);
399 	if (!conf) {
400 		rcu_read_unlock();
401 		return -ENOENT;
402 	}
403 
404 	*def = conf->def;
405 	rcu_read_unlock();
406 
407 	return 0;
408 }
409 
410 static bool ath11k_mac_bitrate_is_cck(int bitrate)
411 {
412 	switch (bitrate) {
413 	case 10:
414 	case 20:
415 	case 55:
416 	case 110:
417 		return true;
418 	}
419 
420 	return false;
421 }
422 
423 u8 ath11k_mac_hw_rate_to_idx(const struct ieee80211_supported_band *sband,
424 			     u8 hw_rate, bool cck)
425 {
426 	const struct ieee80211_rate *rate;
427 	int i;
428 
429 	for (i = 0; i < sband->n_bitrates; i++) {
430 		rate = &sband->bitrates[i];
431 
432 		if (ath11k_mac_bitrate_is_cck(rate->bitrate) != cck)
433 			continue;
434 
435 		if (rate->hw_value == hw_rate)
436 			return i;
437 		else if (rate->flags & IEEE80211_RATE_SHORT_PREAMBLE &&
438 			 rate->hw_value_short == hw_rate)
439 			return i;
440 	}
441 
442 	return 0;
443 }
444 
445 static u8 ath11k_mac_bitrate_to_rate(int bitrate)
446 {
447 	return DIV_ROUND_UP(bitrate, 5) |
448 	       (ath11k_mac_bitrate_is_cck(bitrate) ? BIT(7) : 0);
449 }
450 
451 static void ath11k_get_arvif_iter(void *data, u8 *mac,
452 				  struct ieee80211_vif *vif)
453 {
454 	struct ath11k_vif_iter *arvif_iter = data;
455 	struct ath11k_vif *arvif = (void *)vif->drv_priv;
456 
457 	if (arvif->vdev_id == arvif_iter->vdev_id)
458 		arvif_iter->arvif = arvif;
459 }
460 
461 struct ath11k_vif *ath11k_mac_get_arvif(struct ath11k *ar, u32 vdev_id)
462 {
463 	struct ath11k_vif_iter arvif_iter;
464 	u32 flags;
465 
466 	memset(&arvif_iter, 0, sizeof(struct ath11k_vif_iter));
467 	arvif_iter.vdev_id = vdev_id;
468 
469 	flags = IEEE80211_IFACE_ITER_RESUME_ALL;
470 	ieee80211_iterate_active_interfaces_atomic(ar->hw,
471 						   flags,
472 						   ath11k_get_arvif_iter,
473 						   &arvif_iter);
474 	if (!arvif_iter.arvif) {
475 		ath11k_warn(ar->ab, "No VIF found for vdev %d\n", vdev_id);
476 		return NULL;
477 	}
478 
479 	return arvif_iter.arvif;
480 }
481 
482 struct ath11k_vif *ath11k_mac_get_arvif_by_vdev_id(struct ath11k_base *ab,
483 						   u32 vdev_id)
484 {
485 	int i;
486 	struct ath11k_pdev *pdev;
487 	struct ath11k_vif *arvif;
488 
489 	for (i = 0; i < ab->num_radios; i++) {
490 		pdev = rcu_dereference(ab->pdevs_active[i]);
491 		if (pdev && pdev->ar) {
492 			arvif = ath11k_mac_get_arvif(pdev->ar, vdev_id);
493 			if (arvif)
494 				return arvif;
495 		}
496 	}
497 
498 	return NULL;
499 }
500 
501 struct ath11k *ath11k_mac_get_ar_by_vdev_id(struct ath11k_base *ab, u32 vdev_id)
502 {
503 	int i;
504 	struct ath11k_pdev *pdev;
505 
506 	for (i = 0; i < ab->num_radios; i++) {
507 		pdev = rcu_dereference(ab->pdevs_active[i]);
508 		if (pdev && pdev->ar) {
509 			if (pdev->ar->allocated_vdev_map & (1LL << vdev_id))
510 				return pdev->ar;
511 		}
512 	}
513 
514 	return NULL;
515 }
516 
517 struct ath11k *ath11k_mac_get_ar_by_pdev_id(struct ath11k_base *ab, u32 pdev_id)
518 {
519 	int i;
520 	struct ath11k_pdev *pdev;
521 
522 	if (ab->hw_params.single_pdev_only) {
523 		pdev = rcu_dereference(ab->pdevs_active[0]);
524 		return pdev ? pdev->ar : NULL;
525 	}
526 
527 	if (WARN_ON(pdev_id > ab->num_radios))
528 		return NULL;
529 
530 	for (i = 0; i < ab->num_radios; i++) {
531 		pdev = rcu_dereference(ab->pdevs_active[i]);
532 
533 		if (pdev && pdev->pdev_id == pdev_id)
534 			return (pdev->ar ? pdev->ar : NULL);
535 	}
536 
537 	return NULL;
538 }
539 
540 struct ath11k *ath11k_mac_get_ar_vdev_stop_status(struct ath11k_base *ab,
541 						  u32 vdev_id)
542 {
543 	int i;
544 	struct ath11k_pdev *pdev;
545 	struct ath11k *ar;
546 
547 	for (i = 0; i < ab->num_radios; i++) {
548 		pdev = rcu_dereference(ab->pdevs_active[i]);
549 		if (pdev && pdev->ar) {
550 			ar = pdev->ar;
551 
552 			spin_lock_bh(&ar->data_lock);
553 			if (ar->vdev_stop_status.stop_in_progress &&
554 			    ar->vdev_stop_status.vdev_id == vdev_id) {
555 				ar->vdev_stop_status.stop_in_progress = false;
556 				spin_unlock_bh(&ar->data_lock);
557 				return ar;
558 			}
559 			spin_unlock_bh(&ar->data_lock);
560 		}
561 	}
562 	return NULL;
563 }
564 
565 static void ath11k_pdev_caps_update(struct ath11k *ar)
566 {
567 	struct ath11k_base *ab = ar->ab;
568 
569 	ar->max_tx_power = ab->target_caps.hw_max_tx_power;
570 
571 	/* FIXME Set min_tx_power to ab->target_caps.hw_min_tx_power.
572 	 * But since the received value in svcrdy is same as hw_max_tx_power,
573 	 * we can set ar->min_tx_power to 0 currently until
574 	 * this is fixed in firmware
575 	 */
576 	ar->min_tx_power = 0;
577 
578 	ar->txpower_limit_2g = ar->max_tx_power;
579 	ar->txpower_limit_5g = ar->max_tx_power;
580 	ar->txpower_scale = WMI_HOST_TP_SCALE_MAX;
581 }
582 
583 static int ath11k_mac_txpower_recalc(struct ath11k *ar)
584 {
585 	struct ath11k_pdev *pdev = ar->pdev;
586 	struct ath11k_vif *arvif;
587 	int ret, txpower = -1;
588 	u32 param;
589 
590 	lockdep_assert_held(&ar->conf_mutex);
591 
592 	list_for_each_entry(arvif, &ar->arvifs, list) {
593 		if (arvif->txpower <= 0)
594 			continue;
595 
596 		if (txpower == -1)
597 			txpower = arvif->txpower;
598 		else
599 			txpower = min(txpower, arvif->txpower);
600 	}
601 
602 	if (txpower == -1)
603 		return 0;
604 
605 	/* txpwr is set as 2 units per dBm in FW*/
606 	txpower = min_t(u32, max_t(u32, ar->min_tx_power, txpower),
607 			ar->max_tx_power) * 2;
608 
609 	ath11k_dbg(ar->ab, ATH11K_DBG_MAC, "txpower to set in hw %d\n",
610 		   txpower / 2);
611 
612 	if ((pdev->cap.supported_bands & WMI_HOST_WLAN_2G_CAP) &&
613 	    ar->txpower_limit_2g != txpower) {
614 		param = WMI_PDEV_PARAM_TXPOWER_LIMIT2G;
615 		ret = ath11k_wmi_pdev_set_param(ar, param,
616 						txpower, ar->pdev->pdev_id);
617 		if (ret)
618 			goto fail;
619 		ar->txpower_limit_2g = txpower;
620 	}
621 
622 	if ((pdev->cap.supported_bands & WMI_HOST_WLAN_5G_CAP) &&
623 	    ar->txpower_limit_5g != txpower) {
624 		param = WMI_PDEV_PARAM_TXPOWER_LIMIT5G;
625 		ret = ath11k_wmi_pdev_set_param(ar, param,
626 						txpower, ar->pdev->pdev_id);
627 		if (ret)
628 			goto fail;
629 		ar->txpower_limit_5g = txpower;
630 	}
631 
632 	return 0;
633 
634 fail:
635 	ath11k_warn(ar->ab, "failed to recalc txpower limit %d using pdev param %d: %d\n",
636 		    txpower / 2, param, ret);
637 	return ret;
638 }
639 
640 static int ath11k_recalc_rtscts_prot(struct ath11k_vif *arvif)
641 {
642 	struct ath11k *ar = arvif->ar;
643 	u32 vdev_param, rts_cts = 0;
644 	int ret;
645 
646 	lockdep_assert_held(&ar->conf_mutex);
647 
648 	vdev_param = WMI_VDEV_PARAM_ENABLE_RTSCTS;
649 
650 	/* Enable RTS/CTS protection for sw retries (when legacy stations
651 	 * are in BSS) or by default only for second rate series.
652 	 * TODO: Check if we need to enable CTS 2 Self in any case
653 	 */
654 	rts_cts = WMI_USE_RTS_CTS;
655 
656 	if (arvif->num_legacy_stations > 0)
657 		rts_cts |= WMI_RTSCTS_ACROSS_SW_RETRIES << 4;
658 	else
659 		rts_cts |= WMI_RTSCTS_FOR_SECOND_RATESERIES << 4;
660 
661 	/* Need not send duplicate param value to firmware */
662 	if (arvif->rtscts_prot_mode == rts_cts)
663 		return 0;
664 
665 	arvif->rtscts_prot_mode = rts_cts;
666 
667 	ath11k_dbg(ar->ab, ATH11K_DBG_MAC, "mac vdev %d recalc rts/cts prot %d\n",
668 		   arvif->vdev_id, rts_cts);
669 
670 	ret =  ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
671 					     vdev_param, rts_cts);
672 	if (ret)
673 		ath11k_warn(ar->ab, "failed to recalculate rts/cts prot for vdev %d: %d\n",
674 			    arvif->vdev_id, ret);
675 
676 	return ret;
677 }
678 
679 static int ath11k_mac_set_kickout(struct ath11k_vif *arvif)
680 {
681 	struct ath11k *ar = arvif->ar;
682 	u32 param;
683 	int ret;
684 
685 	ret = ath11k_wmi_pdev_set_param(ar, WMI_PDEV_PARAM_STA_KICKOUT_TH,
686 					ATH11K_KICKOUT_THRESHOLD,
687 					ar->pdev->pdev_id);
688 	if (ret) {
689 		ath11k_warn(ar->ab, "failed to set kickout threshold on vdev %i: %d\n",
690 			    arvif->vdev_id, ret);
691 		return ret;
692 	}
693 
694 	param = WMI_VDEV_PARAM_AP_KEEPALIVE_MIN_IDLE_INACTIVE_TIME_SECS;
695 	ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id, param,
696 					    ATH11K_KEEPALIVE_MIN_IDLE);
697 	if (ret) {
698 		ath11k_warn(ar->ab, "failed to set keepalive minimum idle time on vdev %i: %d\n",
699 			    arvif->vdev_id, ret);
700 		return ret;
701 	}
702 
703 	param = WMI_VDEV_PARAM_AP_KEEPALIVE_MAX_IDLE_INACTIVE_TIME_SECS;
704 	ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id, param,
705 					    ATH11K_KEEPALIVE_MAX_IDLE);
706 	if (ret) {
707 		ath11k_warn(ar->ab, "failed to set keepalive maximum idle time on vdev %i: %d\n",
708 			    arvif->vdev_id, ret);
709 		return ret;
710 	}
711 
712 	param = WMI_VDEV_PARAM_AP_KEEPALIVE_MAX_UNRESPONSIVE_TIME_SECS;
713 	ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id, param,
714 					    ATH11K_KEEPALIVE_MAX_UNRESPONSIVE);
715 	if (ret) {
716 		ath11k_warn(ar->ab, "failed to set keepalive maximum unresponsive time on vdev %i: %d\n",
717 			    arvif->vdev_id, ret);
718 		return ret;
719 	}
720 
721 	return 0;
722 }
723 
724 void ath11k_mac_peer_cleanup_all(struct ath11k *ar)
725 {
726 	struct ath11k_peer *peer, *tmp;
727 	struct ath11k_base *ab = ar->ab;
728 
729 	lockdep_assert_held(&ar->conf_mutex);
730 
731 	spin_lock_bh(&ab->base_lock);
732 	list_for_each_entry_safe(peer, tmp, &ab->peers, list) {
733 		ath11k_peer_rx_tid_cleanup(ar, peer);
734 		list_del(&peer->list);
735 		kfree(peer);
736 	}
737 	spin_unlock_bh(&ab->base_lock);
738 
739 	ar->num_peers = 0;
740 	ar->num_stations = 0;
741 }
742 
743 static int ath11k_monitor_vdev_up(struct ath11k *ar, int vdev_id)
744 {
745 	int ret = 0;
746 
747 	ret = ath11k_wmi_vdev_up(ar, vdev_id, 0, ar->mac_addr);
748 	if (ret) {
749 		ath11k_warn(ar->ab, "failed to put up monitor vdev %i: %d\n",
750 			    vdev_id, ret);
751 		return ret;
752 	}
753 
754 	ath11k_dbg(ar->ab, ATH11K_DBG_MAC, "mac monitor vdev %i started\n",
755 		   vdev_id);
756 	return 0;
757 }
758 
759 static int ath11k_mac_op_config(struct ieee80211_hw *hw, u32 changed)
760 {
761 	/* mac80211 requires this op to be present and that's why
762 	 * there's an empty function, this can be extended when
763 	 * required.
764 	 */
765 
766 	return 0;
767 }
768 
769 static int ath11k_mac_setup_bcn_tmpl(struct ath11k_vif *arvif)
770 {
771 	struct ath11k *ar = arvif->ar;
772 	struct ath11k_base *ab = ar->ab;
773 	struct ieee80211_hw *hw = ar->hw;
774 	struct ieee80211_vif *vif = arvif->vif;
775 	struct ieee80211_mutable_offsets offs = {};
776 	struct sk_buff *bcn;
777 	struct ieee80211_mgmt *mgmt;
778 	u8 *ies;
779 	int ret;
780 
781 	if (arvif->vdev_type != WMI_VDEV_TYPE_AP)
782 		return 0;
783 
784 	bcn = ieee80211_beacon_get_template(hw, vif, &offs);
785 	if (!bcn) {
786 		ath11k_warn(ab, "failed to get beacon template from mac80211\n");
787 		return -EPERM;
788 	}
789 
790 	ies = bcn->data + ieee80211_get_hdrlen_from_skb(bcn);
791 	ies += sizeof(mgmt->u.beacon);
792 
793 	if (cfg80211_find_ie(WLAN_EID_RSN, ies, (skb_tail_pointer(bcn) - ies)))
794 		arvif->rsnie_present = true;
795 
796 	if (cfg80211_find_vendor_ie(WLAN_OUI_MICROSOFT,
797 				    WLAN_OUI_TYPE_MICROSOFT_WPA,
798 				    ies, (skb_tail_pointer(bcn) - ies)))
799 		arvif->wpaie_present = true;
800 
801 	ret = ath11k_wmi_bcn_tmpl(ar, arvif->vdev_id, &offs, bcn);
802 
803 	kfree_skb(bcn);
804 
805 	if (ret)
806 		ath11k_warn(ab, "failed to submit beacon template command: %d\n",
807 			    ret);
808 
809 	return ret;
810 }
811 
812 static void ath11k_control_beaconing(struct ath11k_vif *arvif,
813 				     struct ieee80211_bss_conf *info)
814 {
815 	struct ath11k *ar = arvif->ar;
816 	int ret = 0;
817 
818 	lockdep_assert_held(&arvif->ar->conf_mutex);
819 
820 	if (!info->enable_beacon) {
821 		ret = ath11k_wmi_vdev_down(ar, arvif->vdev_id);
822 		if (ret)
823 			ath11k_warn(ar->ab, "failed to down vdev_id %i: %d\n",
824 				    arvif->vdev_id, ret);
825 
826 		arvif->is_up = false;
827 		return;
828 	}
829 
830 	/* Install the beacon template to the FW */
831 	ret = ath11k_mac_setup_bcn_tmpl(arvif);
832 	if (ret) {
833 		ath11k_warn(ar->ab, "failed to update bcn tmpl during vdev up: %d\n",
834 			    ret);
835 		return;
836 	}
837 
838 	arvif->tx_seq_no = 0x1000;
839 
840 	arvif->aid = 0;
841 
842 	ether_addr_copy(arvif->bssid, info->bssid);
843 
844 	ret = ath11k_wmi_vdev_up(arvif->ar, arvif->vdev_id, arvif->aid,
845 				 arvif->bssid);
846 	if (ret) {
847 		ath11k_warn(ar->ab, "failed to bring up vdev %d: %i\n",
848 			    arvif->vdev_id, ret);
849 		return;
850 	}
851 
852 	arvif->is_up = true;
853 
854 	ath11k_dbg(ar->ab, ATH11K_DBG_MAC, "mac vdev %d up\n", arvif->vdev_id);
855 }
856 
857 static void ath11k_peer_assoc_h_basic(struct ath11k *ar,
858 				      struct ieee80211_vif *vif,
859 				      struct ieee80211_sta *sta,
860 				      struct peer_assoc_params *arg)
861 {
862 	struct ath11k_vif *arvif = (void *)vif->drv_priv;
863 	u32 aid;
864 
865 	lockdep_assert_held(&ar->conf_mutex);
866 
867 	if (vif->type == NL80211_IFTYPE_STATION)
868 		aid = vif->bss_conf.aid;
869 	else
870 		aid = sta->aid;
871 
872 	ether_addr_copy(arg->peer_mac, sta->addr);
873 	arg->vdev_id = arvif->vdev_id;
874 	arg->peer_associd = aid;
875 	arg->auth_flag = true;
876 	/* TODO: STA WAR in ath10k for listen interval required? */
877 	arg->peer_listen_intval = ar->hw->conf.listen_interval;
878 	arg->peer_nss = 1;
879 	arg->peer_caps = vif->bss_conf.assoc_capability;
880 }
881 
882 static void ath11k_peer_assoc_h_crypto(struct ath11k *ar,
883 				       struct ieee80211_vif *vif,
884 				       struct ieee80211_sta *sta,
885 				       struct peer_assoc_params *arg)
886 {
887 	struct ieee80211_bss_conf *info = &vif->bss_conf;
888 	struct cfg80211_chan_def def;
889 	struct cfg80211_bss *bss;
890 	struct ath11k_vif *arvif = (struct ath11k_vif *)vif->drv_priv;
891 	const u8 *rsnie = NULL;
892 	const u8 *wpaie = NULL;
893 
894 	lockdep_assert_held(&ar->conf_mutex);
895 
896 	if (WARN_ON(ath11k_mac_vif_chan(vif, &def)))
897 		return;
898 
899 	bss = cfg80211_get_bss(ar->hw->wiphy, def.chan, info->bssid, NULL, 0,
900 			       IEEE80211_BSS_TYPE_ANY, IEEE80211_PRIVACY_ANY);
901 
902 	if (arvif->rsnie_present || arvif->wpaie_present) {
903 		arg->need_ptk_4_way = true;
904 		if (arvif->wpaie_present)
905 			arg->need_gtk_2_way = true;
906 	} else if (bss) {
907 		const struct cfg80211_bss_ies *ies;
908 
909 		rcu_read_lock();
910 		rsnie = ieee80211_bss_get_ie(bss, WLAN_EID_RSN);
911 
912 		ies = rcu_dereference(bss->ies);
913 
914 		wpaie = cfg80211_find_vendor_ie(WLAN_OUI_MICROSOFT,
915 						WLAN_OUI_TYPE_MICROSOFT_WPA,
916 						ies->data,
917 						ies->len);
918 		rcu_read_unlock();
919 		cfg80211_put_bss(ar->hw->wiphy, bss);
920 	}
921 
922 	/* FIXME: base on RSN IE/WPA IE is a correct idea? */
923 	if (rsnie || wpaie) {
924 		ath11k_dbg(ar->ab, ATH11K_DBG_WMI,
925 			   "%s: rsn ie found\n", __func__);
926 		arg->need_ptk_4_way = true;
927 	}
928 
929 	if (wpaie) {
930 		ath11k_dbg(ar->ab, ATH11K_DBG_WMI,
931 			   "%s: wpa ie found\n", __func__);
932 		arg->need_gtk_2_way = true;
933 	}
934 
935 	if (sta->mfp) {
936 		/* TODO: Need to check if FW supports PMF? */
937 		arg->is_pmf_enabled = true;
938 	}
939 
940 	/* TODO: safe_mode_enabled (bypass 4-way handshake) flag req? */
941 }
942 
943 static void ath11k_peer_assoc_h_rates(struct ath11k *ar,
944 				      struct ieee80211_vif *vif,
945 				      struct ieee80211_sta *sta,
946 				      struct peer_assoc_params *arg)
947 {
948 	struct ath11k_vif *arvif = (void *)vif->drv_priv;
949 	struct wmi_rate_set_arg *rateset = &arg->peer_legacy_rates;
950 	struct cfg80211_chan_def def;
951 	const struct ieee80211_supported_band *sband;
952 	const struct ieee80211_rate *rates;
953 	enum nl80211_band band;
954 	u32 ratemask;
955 	u8 rate;
956 	int i;
957 
958 	lockdep_assert_held(&ar->conf_mutex);
959 
960 	if (WARN_ON(ath11k_mac_vif_chan(vif, &def)))
961 		return;
962 
963 	band = def.chan->band;
964 	sband = ar->hw->wiphy->bands[band];
965 	ratemask = sta->supp_rates[band];
966 	ratemask &= arvif->bitrate_mask.control[band].legacy;
967 	rates = sband->bitrates;
968 
969 	rateset->num_rates = 0;
970 
971 	for (i = 0; i < 32; i++, ratemask >>= 1, rates++) {
972 		if (!(ratemask & 1))
973 			continue;
974 
975 		rate = ath11k_mac_bitrate_to_rate(rates->bitrate);
976 		rateset->rates[rateset->num_rates] = rate;
977 		rateset->num_rates++;
978 	}
979 }
980 
981 static bool
982 ath11k_peer_assoc_h_ht_masked(const u8 ht_mcs_mask[IEEE80211_HT_MCS_MASK_LEN])
983 {
984 	int nss;
985 
986 	for (nss = 0; nss < IEEE80211_HT_MCS_MASK_LEN; nss++)
987 		if (ht_mcs_mask[nss])
988 			return false;
989 
990 	return true;
991 }
992 
993 static bool
994 ath11k_peer_assoc_h_vht_masked(const u16 vht_mcs_mask[NL80211_VHT_NSS_MAX])
995 {
996 	int nss;
997 
998 	for (nss = 0; nss < NL80211_VHT_NSS_MAX; nss++)
999 		if (vht_mcs_mask[nss])
1000 			return false;
1001 
1002 	return true;
1003 }
1004 
1005 static void ath11k_peer_assoc_h_ht(struct ath11k *ar,
1006 				   struct ieee80211_vif *vif,
1007 				   struct ieee80211_sta *sta,
1008 				   struct peer_assoc_params *arg)
1009 {
1010 	const struct ieee80211_sta_ht_cap *ht_cap = &sta->ht_cap;
1011 	struct ath11k_vif *arvif = (void *)vif->drv_priv;
1012 	struct cfg80211_chan_def def;
1013 	enum nl80211_band band;
1014 	const u8 *ht_mcs_mask;
1015 	int i, n;
1016 	u8 max_nss;
1017 	u32 stbc;
1018 
1019 	lockdep_assert_held(&ar->conf_mutex);
1020 
1021 	if (WARN_ON(ath11k_mac_vif_chan(vif, &def)))
1022 		return;
1023 
1024 	if (!ht_cap->ht_supported)
1025 		return;
1026 
1027 	band = def.chan->band;
1028 	ht_mcs_mask = arvif->bitrate_mask.control[band].ht_mcs;
1029 
1030 	if (ath11k_peer_assoc_h_ht_masked(ht_mcs_mask))
1031 		return;
1032 
1033 	arg->ht_flag = true;
1034 
1035 	arg->peer_max_mpdu = (1 << (IEEE80211_HT_MAX_AMPDU_FACTOR +
1036 				    ht_cap->ampdu_factor)) - 1;
1037 
1038 	arg->peer_mpdu_density =
1039 		ath11k_parse_mpdudensity(ht_cap->ampdu_density);
1040 
1041 	arg->peer_ht_caps = ht_cap->cap;
1042 	arg->peer_rate_caps |= WMI_HOST_RC_HT_FLAG;
1043 
1044 	if (ht_cap->cap & IEEE80211_HT_CAP_LDPC_CODING)
1045 		arg->ldpc_flag = true;
1046 
1047 	if (sta->bandwidth >= IEEE80211_STA_RX_BW_40) {
1048 		arg->bw_40 = true;
1049 		arg->peer_rate_caps |= WMI_HOST_RC_CW40_FLAG;
1050 	}
1051 
1052 	if (arvif->bitrate_mask.control[band].gi != NL80211_TXRATE_FORCE_LGI) {
1053 		if (ht_cap->cap & (IEEE80211_HT_CAP_SGI_20 |
1054 		    IEEE80211_HT_CAP_SGI_40))
1055 			arg->peer_rate_caps |= WMI_HOST_RC_SGI_FLAG;
1056 	}
1057 
1058 	if (ht_cap->cap & IEEE80211_HT_CAP_TX_STBC) {
1059 		arg->peer_rate_caps |= WMI_HOST_RC_TX_STBC_FLAG;
1060 		arg->stbc_flag = true;
1061 	}
1062 
1063 	if (ht_cap->cap & IEEE80211_HT_CAP_RX_STBC) {
1064 		stbc = ht_cap->cap & IEEE80211_HT_CAP_RX_STBC;
1065 		stbc = stbc >> IEEE80211_HT_CAP_RX_STBC_SHIFT;
1066 		stbc = stbc << WMI_HOST_RC_RX_STBC_FLAG_S;
1067 		arg->peer_rate_caps |= stbc;
1068 		arg->stbc_flag = true;
1069 	}
1070 
1071 	if (ht_cap->mcs.rx_mask[1] && ht_cap->mcs.rx_mask[2])
1072 		arg->peer_rate_caps |= WMI_HOST_RC_TS_FLAG;
1073 	else if (ht_cap->mcs.rx_mask[1])
1074 		arg->peer_rate_caps |= WMI_HOST_RC_DS_FLAG;
1075 
1076 	for (i = 0, n = 0, max_nss = 0; i < IEEE80211_HT_MCS_MASK_LEN * 8; i++)
1077 		if ((ht_cap->mcs.rx_mask[i / 8] & BIT(i % 8)) &&
1078 		    (ht_mcs_mask[i / 8] & BIT(i % 8))) {
1079 			max_nss = (i / 8) + 1;
1080 			arg->peer_ht_rates.rates[n++] = i;
1081 		}
1082 
1083 	/* This is a workaround for HT-enabled STAs which break the spec
1084 	 * and have no HT capabilities RX mask (no HT RX MCS map).
1085 	 *
1086 	 * As per spec, in section 20.3.5 Modulation and coding scheme (MCS),
1087 	 * MCS 0 through 7 are mandatory in 20MHz with 800 ns GI at all STAs.
1088 	 *
1089 	 * Firmware asserts if such situation occurs.
1090 	 */
1091 	if (n == 0) {
1092 		arg->peer_ht_rates.num_rates = 8;
1093 		for (i = 0; i < arg->peer_ht_rates.num_rates; i++)
1094 			arg->peer_ht_rates.rates[i] = i;
1095 	} else {
1096 		arg->peer_ht_rates.num_rates = n;
1097 		arg->peer_nss = min(sta->rx_nss, max_nss);
1098 	}
1099 
1100 	ath11k_dbg(ar->ab, ATH11K_DBG_MAC, "mac ht peer %pM mcs cnt %d nss %d\n",
1101 		   arg->peer_mac,
1102 		   arg->peer_ht_rates.num_rates,
1103 		   arg->peer_nss);
1104 }
1105 
1106 static int ath11k_mac_get_max_vht_mcs_map(u16 mcs_map, int nss)
1107 {
1108 	switch ((mcs_map >> (2 * nss)) & 0x3) {
1109 	case IEEE80211_VHT_MCS_SUPPORT_0_7: return BIT(8) - 1;
1110 	case IEEE80211_VHT_MCS_SUPPORT_0_8: return BIT(9) - 1;
1111 	case IEEE80211_VHT_MCS_SUPPORT_0_9: return BIT(10) - 1;
1112 	}
1113 	return 0;
1114 }
1115 
1116 static u16
1117 ath11k_peer_assoc_h_vht_limit(u16 tx_mcs_set,
1118 			      const u16 vht_mcs_limit[NL80211_VHT_NSS_MAX])
1119 {
1120 	int idx_limit;
1121 	int nss;
1122 	u16 mcs_map;
1123 	u16 mcs;
1124 
1125 	for (nss = 0; nss < NL80211_VHT_NSS_MAX; nss++) {
1126 		mcs_map = ath11k_mac_get_max_vht_mcs_map(tx_mcs_set, nss) &
1127 			  vht_mcs_limit[nss];
1128 
1129 		if (mcs_map)
1130 			idx_limit = fls(mcs_map) - 1;
1131 		else
1132 			idx_limit = -1;
1133 
1134 		switch (idx_limit) {
1135 		case 0:
1136 		case 1:
1137 		case 2:
1138 		case 3:
1139 		case 4:
1140 		case 5:
1141 		case 6:
1142 		case 7:
1143 			mcs = IEEE80211_VHT_MCS_SUPPORT_0_7;
1144 			break;
1145 		case 8:
1146 			mcs = IEEE80211_VHT_MCS_SUPPORT_0_8;
1147 			break;
1148 		case 9:
1149 			mcs = IEEE80211_VHT_MCS_SUPPORT_0_9;
1150 			break;
1151 		default:
1152 			WARN_ON(1);
1153 			fallthrough;
1154 		case -1:
1155 			mcs = IEEE80211_VHT_MCS_NOT_SUPPORTED;
1156 			break;
1157 		}
1158 
1159 		tx_mcs_set &= ~(0x3 << (nss * 2));
1160 		tx_mcs_set |= mcs << (nss * 2);
1161 	}
1162 
1163 	return tx_mcs_set;
1164 }
1165 
1166 static void ath11k_peer_assoc_h_vht(struct ath11k *ar,
1167 				    struct ieee80211_vif *vif,
1168 				    struct ieee80211_sta *sta,
1169 				    struct peer_assoc_params *arg)
1170 {
1171 	const struct ieee80211_sta_vht_cap *vht_cap = &sta->vht_cap;
1172 	struct ath11k_vif *arvif = (void *)vif->drv_priv;
1173 	struct cfg80211_chan_def def;
1174 	enum nl80211_band band;
1175 	const u16 *vht_mcs_mask;
1176 	u8 ampdu_factor;
1177 	u8 max_nss, vht_mcs;
1178 	int i;
1179 
1180 	if (WARN_ON(ath11k_mac_vif_chan(vif, &def)))
1181 		return;
1182 
1183 	if (!vht_cap->vht_supported)
1184 		return;
1185 
1186 	band = def.chan->band;
1187 	vht_mcs_mask = arvif->bitrate_mask.control[band].vht_mcs;
1188 
1189 	if (ath11k_peer_assoc_h_vht_masked(vht_mcs_mask))
1190 		return;
1191 
1192 	arg->vht_flag = true;
1193 
1194 	/* TODO: similar flags required? */
1195 	arg->vht_capable = true;
1196 
1197 	if (def.chan->band == NL80211_BAND_2GHZ)
1198 		arg->vht_ng_flag = true;
1199 
1200 	arg->peer_vht_caps = vht_cap->cap;
1201 
1202 	ampdu_factor = (vht_cap->cap &
1203 			IEEE80211_VHT_CAP_MAX_A_MPDU_LENGTH_EXPONENT_MASK) >>
1204 		       IEEE80211_VHT_CAP_MAX_A_MPDU_LENGTH_EXPONENT_SHIFT;
1205 
1206 	/* Workaround: Some Netgear/Linksys 11ac APs set Rx A-MPDU factor to
1207 	 * zero in VHT IE. Using it would result in degraded throughput.
1208 	 * arg->peer_max_mpdu at this point contains HT max_mpdu so keep
1209 	 * it if VHT max_mpdu is smaller.
1210 	 */
1211 	arg->peer_max_mpdu = max(arg->peer_max_mpdu,
1212 				 (1U << (IEEE80211_HT_MAX_AMPDU_FACTOR +
1213 					ampdu_factor)) - 1);
1214 
1215 	if (sta->bandwidth == IEEE80211_STA_RX_BW_80)
1216 		arg->bw_80 = true;
1217 
1218 	if (sta->bandwidth == IEEE80211_STA_RX_BW_160)
1219 		arg->bw_160 = true;
1220 
1221 	/* Calculate peer NSS capability from VHT capabilities if STA
1222 	 * supports VHT.
1223 	 */
1224 	for (i = 0, max_nss = 0, vht_mcs = 0; i < NL80211_VHT_NSS_MAX; i++) {
1225 		vht_mcs = __le16_to_cpu(vht_cap->vht_mcs.rx_mcs_map) >>
1226 			  (2 * i) & 3;
1227 
1228 		if (vht_mcs != IEEE80211_VHT_MCS_NOT_SUPPORTED &&
1229 		    vht_mcs_mask[i])
1230 			max_nss = i + 1;
1231 	}
1232 	arg->peer_nss = min(sta->rx_nss, max_nss);
1233 	arg->rx_max_rate = __le16_to_cpu(vht_cap->vht_mcs.rx_highest);
1234 	arg->rx_mcs_set = __le16_to_cpu(vht_cap->vht_mcs.rx_mcs_map);
1235 	arg->tx_max_rate = __le16_to_cpu(vht_cap->vht_mcs.tx_highest);
1236 	arg->tx_mcs_set = ath11k_peer_assoc_h_vht_limit(
1237 		__le16_to_cpu(vht_cap->vht_mcs.tx_mcs_map), vht_mcs_mask);
1238 
1239 	/* In IPQ8074 platform, VHT mcs rate 10 and 11 is enabled by default.
1240 	 * VHT mcs rate 10 and 11 is not suppoerted in 11ac standard.
1241 	 * so explicitly disable the VHT MCS rate 10 and 11 in 11ac mode.
1242 	 */
1243 	arg->tx_mcs_set &= ~IEEE80211_VHT_MCS_SUPPORT_0_11_MASK;
1244 	arg->tx_mcs_set |= IEEE80211_DISABLE_VHT_MCS_SUPPORT_0_11;
1245 
1246 	if ((arg->tx_mcs_set & IEEE80211_VHT_MCS_NOT_SUPPORTED) ==
1247 			IEEE80211_VHT_MCS_NOT_SUPPORTED)
1248 		arg->peer_vht_caps &= ~IEEE80211_VHT_CAP_MU_BEAMFORMEE_CAPABLE;
1249 
1250 	/* TODO:  Check */
1251 	arg->tx_max_mcs_nss = 0xFF;
1252 
1253 	ath11k_dbg(ar->ab, ATH11K_DBG_MAC, "mac vht peer %pM max_mpdu %d flags 0x%x\n",
1254 		   sta->addr, arg->peer_max_mpdu, arg->peer_flags);
1255 
1256 	/* TODO: rxnss_override */
1257 }
1258 
1259 static void ath11k_peer_assoc_h_he(struct ath11k *ar,
1260 				   struct ieee80211_vif *vif,
1261 				   struct ieee80211_sta *sta,
1262 				   struct peer_assoc_params *arg)
1263 {
1264 	const struct ieee80211_sta_he_cap *he_cap = &sta->he_cap;
1265 	u8 ampdu_factor;
1266 	u16 v;
1267 
1268 	if (!he_cap->has_he)
1269 		return;
1270 
1271 	arg->he_flag = true;
1272 
1273 	memcpy(&arg->peer_he_cap_macinfo, he_cap->he_cap_elem.mac_cap_info,
1274 	       sizeof(arg->peer_he_cap_macinfo));
1275 	memcpy(&arg->peer_he_cap_phyinfo, he_cap->he_cap_elem.phy_cap_info,
1276 	       sizeof(arg->peer_he_cap_phyinfo));
1277 	arg->peer_he_ops = vif->bss_conf.he_oper.params;
1278 
1279 	/* the top most byte is used to indicate BSS color info */
1280 	arg->peer_he_ops &= 0xffffff;
1281 
1282 	/* As per section 26.6.1 11ax Draft5.0, if the Max AMPDU Exponent Extension
1283 	 * in HE cap is zero, use the arg->peer_max_mpdu as calculated while parsing
1284 	 * VHT caps(if VHT caps is present) or HT caps (if VHT caps is not present).
1285 	 *
1286 	 * For non-zero value of Max AMPDU Extponent Extension in HE MAC caps,
1287 	 * if a HE STA sends VHT cap and HE cap IE in assoc request then, use
1288 	 * MAX_AMPDU_LEN_FACTOR as 20 to calculate max_ampdu length.
1289 	 * If a HE STA that does not send VHT cap, but HE and HT cap in assoc
1290 	 * request, then use MAX_AMPDU_LEN_FACTOR as 16 to calculate max_ampdu
1291 	 * length.
1292 	 */
1293 	ampdu_factor = (he_cap->he_cap_elem.mac_cap_info[3] &
1294 			IEEE80211_HE_MAC_CAP3_MAX_AMPDU_LEN_EXP_MASK) >>
1295 			IEEE80211_HE_MAC_CAP3_MAX_AMPDU_LEN_EXP_SHIFT;
1296 
1297 	if (ampdu_factor) {
1298 		if (sta->vht_cap.vht_supported)
1299 			arg->peer_max_mpdu = (1 << (IEEE80211_HE_VHT_MAX_AMPDU_FACTOR +
1300 						    ampdu_factor)) - 1;
1301 		else if (sta->ht_cap.ht_supported)
1302 			arg->peer_max_mpdu = (1 << (IEEE80211_HE_HT_MAX_AMPDU_FACTOR +
1303 						    ampdu_factor)) - 1;
1304 	}
1305 
1306 	if (he_cap->he_cap_elem.phy_cap_info[6] &
1307 	    IEEE80211_HE_PHY_CAP6_PPE_THRESHOLD_PRESENT) {
1308 		int bit = 7;
1309 		int nss, ru;
1310 
1311 		arg->peer_ppet.numss_m1 = he_cap->ppe_thres[0] &
1312 					  IEEE80211_PPE_THRES_NSS_MASK;
1313 		arg->peer_ppet.ru_bit_mask =
1314 			(he_cap->ppe_thres[0] &
1315 			 IEEE80211_PPE_THRES_RU_INDEX_BITMASK_MASK) >>
1316 			IEEE80211_PPE_THRES_RU_INDEX_BITMASK_POS;
1317 
1318 		for (nss = 0; nss <= arg->peer_ppet.numss_m1; nss++) {
1319 			for (ru = 0; ru < 4; ru++) {
1320 				u32 val = 0;
1321 				int i;
1322 
1323 				if ((arg->peer_ppet.ru_bit_mask & BIT(ru)) == 0)
1324 					continue;
1325 				for (i = 0; i < 6; i++) {
1326 					val >>= 1;
1327 					val |= ((he_cap->ppe_thres[bit / 8] >>
1328 						 (bit % 8)) & 0x1) << 5;
1329 					bit++;
1330 				}
1331 				arg->peer_ppet.ppet16_ppet8_ru3_ru0[nss] |=
1332 								val << (ru * 6);
1333 			}
1334 		}
1335 	}
1336 
1337 	if (he_cap->he_cap_elem.mac_cap_info[0] & IEEE80211_HE_MAC_CAP0_TWT_RES)
1338 		arg->twt_responder = true;
1339 	if (he_cap->he_cap_elem.mac_cap_info[0] & IEEE80211_HE_MAC_CAP0_TWT_REQ)
1340 		arg->twt_requester = true;
1341 
1342 	switch (sta->bandwidth) {
1343 	case IEEE80211_STA_RX_BW_160:
1344 		if (he_cap->he_cap_elem.phy_cap_info[0] &
1345 		    IEEE80211_HE_PHY_CAP0_CHANNEL_WIDTH_SET_80PLUS80_MHZ_IN_5G) {
1346 			v = le16_to_cpu(he_cap->he_mcs_nss_supp.rx_mcs_80p80);
1347 			arg->peer_he_rx_mcs_set[WMI_HECAP_TXRX_MCS_NSS_IDX_80_80] = v;
1348 
1349 			v = le16_to_cpu(he_cap->he_mcs_nss_supp.tx_mcs_80p80);
1350 			arg->peer_he_tx_mcs_set[WMI_HECAP_TXRX_MCS_NSS_IDX_80_80] = v;
1351 
1352 			arg->peer_he_mcs_count++;
1353 		}
1354 		v = le16_to_cpu(he_cap->he_mcs_nss_supp.rx_mcs_160);
1355 		arg->peer_he_rx_mcs_set[WMI_HECAP_TXRX_MCS_NSS_IDX_160] = v;
1356 
1357 		v = le16_to_cpu(he_cap->he_mcs_nss_supp.tx_mcs_160);
1358 		arg->peer_he_tx_mcs_set[WMI_HECAP_TXRX_MCS_NSS_IDX_160] = v;
1359 
1360 		arg->peer_he_mcs_count++;
1361 		fallthrough;
1362 
1363 	default:
1364 		v = le16_to_cpu(he_cap->he_mcs_nss_supp.rx_mcs_80);
1365 		arg->peer_he_rx_mcs_set[WMI_HECAP_TXRX_MCS_NSS_IDX_80] = v;
1366 
1367 		v = le16_to_cpu(he_cap->he_mcs_nss_supp.tx_mcs_80);
1368 		arg->peer_he_tx_mcs_set[WMI_HECAP_TXRX_MCS_NSS_IDX_80] = v;
1369 
1370 		arg->peer_he_mcs_count++;
1371 		break;
1372 	}
1373 }
1374 
1375 static void ath11k_peer_assoc_h_smps(struct ieee80211_sta *sta,
1376 				     struct peer_assoc_params *arg)
1377 {
1378 	const struct ieee80211_sta_ht_cap *ht_cap = &sta->ht_cap;
1379 	int smps;
1380 
1381 	if (!ht_cap->ht_supported)
1382 		return;
1383 
1384 	smps = ht_cap->cap & IEEE80211_HT_CAP_SM_PS;
1385 	smps >>= IEEE80211_HT_CAP_SM_PS_SHIFT;
1386 
1387 	switch (smps) {
1388 	case WLAN_HT_CAP_SM_PS_STATIC:
1389 		arg->static_mimops_flag = true;
1390 		break;
1391 	case WLAN_HT_CAP_SM_PS_DYNAMIC:
1392 		arg->dynamic_mimops_flag = true;
1393 		break;
1394 	case WLAN_HT_CAP_SM_PS_DISABLED:
1395 		arg->spatial_mux_flag = true;
1396 		break;
1397 	default:
1398 		break;
1399 	}
1400 }
1401 
1402 static void ath11k_peer_assoc_h_qos(struct ath11k *ar,
1403 				    struct ieee80211_vif *vif,
1404 				    struct ieee80211_sta *sta,
1405 				    struct peer_assoc_params *arg)
1406 {
1407 	struct ath11k_vif *arvif = (void *)vif->drv_priv;
1408 
1409 	switch (arvif->vdev_type) {
1410 	case WMI_VDEV_TYPE_AP:
1411 		if (sta->wme) {
1412 			/* TODO: Check WME vs QoS */
1413 			arg->is_wme_set = true;
1414 			arg->qos_flag = true;
1415 		}
1416 
1417 		if (sta->wme && sta->uapsd_queues) {
1418 			/* TODO: Check WME vs QoS */
1419 			arg->is_wme_set = true;
1420 			arg->apsd_flag = true;
1421 			arg->peer_rate_caps |= WMI_HOST_RC_UAPSD_FLAG;
1422 		}
1423 		break;
1424 	case WMI_VDEV_TYPE_STA:
1425 		if (sta->wme) {
1426 			arg->is_wme_set = true;
1427 			arg->qos_flag = true;
1428 		}
1429 		break;
1430 	default:
1431 		break;
1432 	}
1433 
1434 	ath11k_dbg(ar->ab, ATH11K_DBG_MAC, "mac peer %pM qos %d\n",
1435 		   sta->addr, arg->qos_flag);
1436 }
1437 
1438 static int ath11k_peer_assoc_qos_ap(struct ath11k *ar,
1439 				    struct ath11k_vif *arvif,
1440 				    struct ieee80211_sta *sta)
1441 {
1442 	struct ap_ps_params params;
1443 	u32 max_sp;
1444 	u32 uapsd;
1445 	int ret;
1446 
1447 	lockdep_assert_held(&ar->conf_mutex);
1448 
1449 	params.vdev_id = arvif->vdev_id;
1450 
1451 	ath11k_dbg(ar->ab, ATH11K_DBG_MAC, "mac uapsd_queues 0x%x max_sp %d\n",
1452 		   sta->uapsd_queues, sta->max_sp);
1453 
1454 	uapsd = 0;
1455 	if (sta->uapsd_queues & IEEE80211_WMM_IE_STA_QOSINFO_AC_VO)
1456 		uapsd |= WMI_AP_PS_UAPSD_AC3_DELIVERY_EN |
1457 			 WMI_AP_PS_UAPSD_AC3_TRIGGER_EN;
1458 	if (sta->uapsd_queues & IEEE80211_WMM_IE_STA_QOSINFO_AC_VI)
1459 		uapsd |= WMI_AP_PS_UAPSD_AC2_DELIVERY_EN |
1460 			 WMI_AP_PS_UAPSD_AC2_TRIGGER_EN;
1461 	if (sta->uapsd_queues & IEEE80211_WMM_IE_STA_QOSINFO_AC_BK)
1462 		uapsd |= WMI_AP_PS_UAPSD_AC1_DELIVERY_EN |
1463 			 WMI_AP_PS_UAPSD_AC1_TRIGGER_EN;
1464 	if (sta->uapsd_queues & IEEE80211_WMM_IE_STA_QOSINFO_AC_BE)
1465 		uapsd |= WMI_AP_PS_UAPSD_AC0_DELIVERY_EN |
1466 			 WMI_AP_PS_UAPSD_AC0_TRIGGER_EN;
1467 
1468 	max_sp = 0;
1469 	if (sta->max_sp < MAX_WMI_AP_PS_PEER_PARAM_MAX_SP)
1470 		max_sp = sta->max_sp;
1471 
1472 	params.param = WMI_AP_PS_PEER_PARAM_UAPSD;
1473 	params.value = uapsd;
1474 	ret = ath11k_wmi_send_set_ap_ps_param_cmd(ar, sta->addr, &params);
1475 	if (ret)
1476 		goto err;
1477 
1478 	params.param = WMI_AP_PS_PEER_PARAM_MAX_SP;
1479 	params.value = max_sp;
1480 	ret = ath11k_wmi_send_set_ap_ps_param_cmd(ar, sta->addr, &params);
1481 	if (ret)
1482 		goto err;
1483 
1484 	/* TODO revisit during testing */
1485 	params.param = WMI_AP_PS_PEER_PARAM_SIFS_RESP_FRMTYPE;
1486 	params.value = DISABLE_SIFS_RESPONSE_TRIGGER;
1487 	ret = ath11k_wmi_send_set_ap_ps_param_cmd(ar, sta->addr, &params);
1488 	if (ret)
1489 		goto err;
1490 
1491 	params.param = WMI_AP_PS_PEER_PARAM_SIFS_RESP_UAPSD;
1492 	params.value = DISABLE_SIFS_RESPONSE_TRIGGER;
1493 	ret = ath11k_wmi_send_set_ap_ps_param_cmd(ar, sta->addr, &params);
1494 	if (ret)
1495 		goto err;
1496 
1497 	return 0;
1498 
1499 err:
1500 	ath11k_warn(ar->ab, "failed to set ap ps peer param %d for vdev %i: %d\n",
1501 		    params.param, arvif->vdev_id, ret);
1502 	return ret;
1503 }
1504 
1505 static bool ath11k_mac_sta_has_ofdm_only(struct ieee80211_sta *sta)
1506 {
1507 	return sta->supp_rates[NL80211_BAND_2GHZ] >>
1508 	       ATH11K_MAC_FIRST_OFDM_RATE_IDX;
1509 }
1510 
1511 static enum wmi_phy_mode ath11k_mac_get_phymode_vht(struct ath11k *ar,
1512 						    struct ieee80211_sta *sta)
1513 {
1514 	if (sta->bandwidth == IEEE80211_STA_RX_BW_160) {
1515 		switch (sta->vht_cap.cap &
1516 			IEEE80211_VHT_CAP_SUPP_CHAN_WIDTH_MASK) {
1517 		case IEEE80211_VHT_CAP_SUPP_CHAN_WIDTH_160MHZ:
1518 			return MODE_11AC_VHT160;
1519 		case IEEE80211_VHT_CAP_SUPP_CHAN_WIDTH_160_80PLUS80MHZ:
1520 			return MODE_11AC_VHT80_80;
1521 		default:
1522 			/* not sure if this is a valid case? */
1523 			return MODE_11AC_VHT160;
1524 		}
1525 	}
1526 
1527 	if (sta->bandwidth == IEEE80211_STA_RX_BW_80)
1528 		return MODE_11AC_VHT80;
1529 
1530 	if (sta->bandwidth == IEEE80211_STA_RX_BW_40)
1531 		return MODE_11AC_VHT40;
1532 
1533 	if (sta->bandwidth == IEEE80211_STA_RX_BW_20)
1534 		return MODE_11AC_VHT20;
1535 
1536 	return MODE_UNKNOWN;
1537 }
1538 
1539 static enum wmi_phy_mode ath11k_mac_get_phymode_he(struct ath11k *ar,
1540 						   struct ieee80211_sta *sta)
1541 {
1542 	if (sta->bandwidth == IEEE80211_STA_RX_BW_160) {
1543 		if (sta->he_cap.he_cap_elem.phy_cap_info[0] &
1544 		     IEEE80211_HE_PHY_CAP0_CHANNEL_WIDTH_SET_160MHZ_IN_5G)
1545 			return MODE_11AX_HE160;
1546 		else if (sta->he_cap.he_cap_elem.phy_cap_info[0] &
1547 		     IEEE80211_HE_PHY_CAP0_CHANNEL_WIDTH_SET_80PLUS80_MHZ_IN_5G)
1548 			return MODE_11AX_HE80_80;
1549 		/* not sure if this is a valid case? */
1550 		return MODE_11AX_HE160;
1551 	}
1552 
1553 	if (sta->bandwidth == IEEE80211_STA_RX_BW_80)
1554 		return MODE_11AX_HE80;
1555 
1556 	if (sta->bandwidth == IEEE80211_STA_RX_BW_40)
1557 		return MODE_11AX_HE40;
1558 
1559 	if (sta->bandwidth == IEEE80211_STA_RX_BW_20)
1560 		return MODE_11AX_HE20;
1561 
1562 	return MODE_UNKNOWN;
1563 }
1564 
1565 static void ath11k_peer_assoc_h_phymode(struct ath11k *ar,
1566 					struct ieee80211_vif *vif,
1567 					struct ieee80211_sta *sta,
1568 					struct peer_assoc_params *arg)
1569 {
1570 	struct ath11k_vif *arvif = (void *)vif->drv_priv;
1571 	struct cfg80211_chan_def def;
1572 	enum nl80211_band band;
1573 	const u8 *ht_mcs_mask;
1574 	const u16 *vht_mcs_mask;
1575 	enum wmi_phy_mode phymode = MODE_UNKNOWN;
1576 
1577 	if (WARN_ON(ath11k_mac_vif_chan(vif, &def)))
1578 		return;
1579 
1580 	band = def.chan->band;
1581 	ht_mcs_mask = arvif->bitrate_mask.control[band].ht_mcs;
1582 	vht_mcs_mask = arvif->bitrate_mask.control[band].vht_mcs;
1583 
1584 	switch (band) {
1585 	case NL80211_BAND_2GHZ:
1586 		if (sta->he_cap.has_he) {
1587 			if (sta->bandwidth == IEEE80211_STA_RX_BW_80)
1588 				phymode = MODE_11AX_HE80_2G;
1589 			else if (sta->bandwidth == IEEE80211_STA_RX_BW_40)
1590 				phymode = MODE_11AX_HE40_2G;
1591 			else
1592 				phymode = MODE_11AX_HE20_2G;
1593 		} else if (sta->vht_cap.vht_supported &&
1594 		    !ath11k_peer_assoc_h_vht_masked(vht_mcs_mask)) {
1595 			if (sta->bandwidth == IEEE80211_STA_RX_BW_40)
1596 				phymode = MODE_11AC_VHT40;
1597 			else
1598 				phymode = MODE_11AC_VHT20;
1599 		} else if (sta->ht_cap.ht_supported &&
1600 			   !ath11k_peer_assoc_h_ht_masked(ht_mcs_mask)) {
1601 			if (sta->bandwidth == IEEE80211_STA_RX_BW_40)
1602 				phymode = MODE_11NG_HT40;
1603 			else
1604 				phymode = MODE_11NG_HT20;
1605 		} else if (ath11k_mac_sta_has_ofdm_only(sta)) {
1606 			phymode = MODE_11G;
1607 		} else {
1608 			phymode = MODE_11B;
1609 		}
1610 		break;
1611 	case NL80211_BAND_5GHZ:
1612 	case NL80211_BAND_6GHZ:
1613 		/* Check HE first */
1614 		if (sta->he_cap.has_he) {
1615 			phymode = ath11k_mac_get_phymode_he(ar, sta);
1616 		} else if (sta->vht_cap.vht_supported &&
1617 		    !ath11k_peer_assoc_h_vht_masked(vht_mcs_mask)) {
1618 			phymode = ath11k_mac_get_phymode_vht(ar, sta);
1619 		} else if (sta->ht_cap.ht_supported &&
1620 			   !ath11k_peer_assoc_h_ht_masked(ht_mcs_mask)) {
1621 			if (sta->bandwidth >= IEEE80211_STA_RX_BW_40)
1622 				phymode = MODE_11NA_HT40;
1623 			else
1624 				phymode = MODE_11NA_HT20;
1625 		} else {
1626 			phymode = MODE_11A;
1627 		}
1628 		break;
1629 	default:
1630 		break;
1631 	}
1632 
1633 	ath11k_dbg(ar->ab, ATH11K_DBG_MAC, "mac peer %pM phymode %s\n",
1634 		   sta->addr, ath11k_wmi_phymode_str(phymode));
1635 
1636 	arg->peer_phymode = phymode;
1637 	WARN_ON(phymode == MODE_UNKNOWN);
1638 }
1639 
1640 static void ath11k_peer_assoc_prepare(struct ath11k *ar,
1641 				      struct ieee80211_vif *vif,
1642 				      struct ieee80211_sta *sta,
1643 				      struct peer_assoc_params *arg,
1644 				      bool reassoc)
1645 {
1646 	lockdep_assert_held(&ar->conf_mutex);
1647 
1648 	memset(arg, 0, sizeof(*arg));
1649 
1650 	reinit_completion(&ar->peer_assoc_done);
1651 
1652 	arg->peer_new_assoc = !reassoc;
1653 	ath11k_peer_assoc_h_basic(ar, vif, sta, arg);
1654 	ath11k_peer_assoc_h_crypto(ar, vif, sta, arg);
1655 	ath11k_peer_assoc_h_rates(ar, vif, sta, arg);
1656 	ath11k_peer_assoc_h_ht(ar, vif, sta, arg);
1657 	ath11k_peer_assoc_h_vht(ar, vif, sta, arg);
1658 	ath11k_peer_assoc_h_he(ar, vif, sta, arg);
1659 	ath11k_peer_assoc_h_qos(ar, vif, sta, arg);
1660 	ath11k_peer_assoc_h_phymode(ar, vif, sta, arg);
1661 	ath11k_peer_assoc_h_smps(sta, arg);
1662 
1663 	/* TODO: amsdu_disable req? */
1664 }
1665 
1666 static int ath11k_setup_peer_smps(struct ath11k *ar, struct ath11k_vif *arvif,
1667 				  const u8 *addr,
1668 				  const struct ieee80211_sta_ht_cap *ht_cap)
1669 {
1670 	int smps;
1671 
1672 	if (!ht_cap->ht_supported)
1673 		return 0;
1674 
1675 	smps = ht_cap->cap & IEEE80211_HT_CAP_SM_PS;
1676 	smps >>= IEEE80211_HT_CAP_SM_PS_SHIFT;
1677 
1678 	if (smps >= ARRAY_SIZE(ath11k_smps_map))
1679 		return -EINVAL;
1680 
1681 	return ath11k_wmi_set_peer_param(ar, addr, arvif->vdev_id,
1682 					 WMI_PEER_MIMO_PS_STATE,
1683 					 ath11k_smps_map[smps]);
1684 }
1685 
1686 static void ath11k_bss_assoc(struct ieee80211_hw *hw,
1687 			     struct ieee80211_vif *vif,
1688 			     struct ieee80211_bss_conf *bss_conf)
1689 {
1690 	struct ath11k *ar = hw->priv;
1691 	struct ath11k_vif *arvif = (void *)vif->drv_priv;
1692 	struct peer_assoc_params peer_arg;
1693 	struct ieee80211_sta *ap_sta;
1694 	int ret;
1695 
1696 	lockdep_assert_held(&ar->conf_mutex);
1697 
1698 	ath11k_dbg(ar->ab, ATH11K_DBG_MAC, "mac vdev %i assoc bssid %pM aid %d\n",
1699 		   arvif->vdev_id, arvif->bssid, arvif->aid);
1700 
1701 	rcu_read_lock();
1702 
1703 	ap_sta = ieee80211_find_sta(vif, bss_conf->bssid);
1704 	if (!ap_sta) {
1705 		ath11k_warn(ar->ab, "failed to find station entry for bss %pM vdev %i\n",
1706 			    bss_conf->bssid, arvif->vdev_id);
1707 		rcu_read_unlock();
1708 		return;
1709 	}
1710 
1711 	ath11k_peer_assoc_prepare(ar, vif, ap_sta, &peer_arg, false);
1712 
1713 	rcu_read_unlock();
1714 
1715 	ret = ath11k_wmi_send_peer_assoc_cmd(ar, &peer_arg);
1716 	if (ret) {
1717 		ath11k_warn(ar->ab, "failed to run peer assoc for %pM vdev %i: %d\n",
1718 			    bss_conf->bssid, arvif->vdev_id, ret);
1719 		return;
1720 	}
1721 
1722 	if (!wait_for_completion_timeout(&ar->peer_assoc_done, 1 * HZ)) {
1723 		ath11k_warn(ar->ab, "failed to get peer assoc conf event for %pM vdev %i\n",
1724 			    bss_conf->bssid, arvif->vdev_id);
1725 		return;
1726 	}
1727 
1728 	ret = ath11k_setup_peer_smps(ar, arvif, bss_conf->bssid,
1729 				     &ap_sta->ht_cap);
1730 	if (ret) {
1731 		ath11k_warn(ar->ab, "failed to setup peer SMPS for vdev %d: %d\n",
1732 			    arvif->vdev_id, ret);
1733 		return;
1734 	}
1735 
1736 	WARN_ON(arvif->is_up);
1737 
1738 	arvif->aid = bss_conf->aid;
1739 	ether_addr_copy(arvif->bssid, bss_conf->bssid);
1740 
1741 	ret = ath11k_wmi_vdev_up(ar, arvif->vdev_id, arvif->aid, arvif->bssid);
1742 	if (ret) {
1743 		ath11k_warn(ar->ab, "failed to set vdev %d up: %d\n",
1744 			    arvif->vdev_id, ret);
1745 		return;
1746 	}
1747 
1748 	arvif->is_up = true;
1749 
1750 	ath11k_dbg(ar->ab, ATH11K_DBG_MAC,
1751 		   "mac vdev %d up (associated) bssid %pM aid %d\n",
1752 		   arvif->vdev_id, bss_conf->bssid, bss_conf->aid);
1753 
1754 	/* Authorize BSS Peer */
1755 	ret = ath11k_wmi_set_peer_param(ar, arvif->bssid,
1756 					arvif->vdev_id,
1757 					WMI_PEER_AUTHORIZE,
1758 					1);
1759 	if (ret)
1760 		ath11k_warn(ar->ab, "Unable to authorize BSS peer: %d\n", ret);
1761 
1762 	ret = ath11k_wmi_send_obss_spr_cmd(ar, arvif->vdev_id,
1763 					   &bss_conf->he_obss_pd);
1764 	if (ret)
1765 		ath11k_warn(ar->ab, "failed to set vdev %i OBSS PD parameters: %d\n",
1766 			    arvif->vdev_id, ret);
1767 }
1768 
1769 static void ath11k_bss_disassoc(struct ieee80211_hw *hw,
1770 				struct ieee80211_vif *vif)
1771 {
1772 	struct ath11k *ar = hw->priv;
1773 	struct ath11k_vif *arvif = (void *)vif->drv_priv;
1774 	int ret;
1775 
1776 	lockdep_assert_held(&ar->conf_mutex);
1777 
1778 	ath11k_dbg(ar->ab, ATH11K_DBG_MAC, "mac vdev %i disassoc bssid %pM\n",
1779 		   arvif->vdev_id, arvif->bssid);
1780 
1781 	ret = ath11k_wmi_vdev_down(ar, arvif->vdev_id);
1782 	if (ret)
1783 		ath11k_warn(ar->ab, "failed to down vdev %i: %d\n",
1784 			    arvif->vdev_id, ret);
1785 
1786 	arvif->is_up = false;
1787 
1788 	/* TODO: cancel connection_loss_work */
1789 }
1790 
1791 static u32 ath11k_mac_get_rate_hw_value(int bitrate)
1792 {
1793 	u32 preamble;
1794 	u16 hw_value;
1795 	int rate;
1796 	size_t i;
1797 
1798 	if (ath11k_mac_bitrate_is_cck(bitrate))
1799 		preamble = WMI_RATE_PREAMBLE_CCK;
1800 	else
1801 		preamble = WMI_RATE_PREAMBLE_OFDM;
1802 
1803 	for (i = 0; i < ARRAY_SIZE(ath11k_legacy_rates); i++) {
1804 		if (ath11k_legacy_rates[i].bitrate != bitrate)
1805 			continue;
1806 
1807 		hw_value = ath11k_legacy_rates[i].hw_value;
1808 		rate = ATH11K_HW_RATE_CODE(hw_value, 0, preamble);
1809 
1810 		return rate;
1811 	}
1812 
1813 	return -EINVAL;
1814 }
1815 
1816 static void ath11k_recalculate_mgmt_rate(struct ath11k *ar,
1817 					 struct ieee80211_vif *vif,
1818 					 struct cfg80211_chan_def *def)
1819 {
1820 	struct ath11k_vif *arvif = (void *)vif->drv_priv;
1821 	const struct ieee80211_supported_band *sband;
1822 	u8 basic_rate_idx;
1823 	int hw_rate_code;
1824 	u32 vdev_param;
1825 	u16 bitrate;
1826 	int ret;
1827 
1828 	lockdep_assert_held(&ar->conf_mutex);
1829 
1830 	sband = ar->hw->wiphy->bands[def->chan->band];
1831 	basic_rate_idx = ffs(vif->bss_conf.basic_rates) - 1;
1832 	bitrate = sband->bitrates[basic_rate_idx].bitrate;
1833 
1834 	hw_rate_code = ath11k_mac_get_rate_hw_value(bitrate);
1835 	if (hw_rate_code < 0) {
1836 		ath11k_warn(ar->ab, "bitrate not supported %d\n", bitrate);
1837 		return;
1838 	}
1839 
1840 	vdev_param = WMI_VDEV_PARAM_MGMT_RATE;
1841 	ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id, vdev_param,
1842 					    hw_rate_code);
1843 	if (ret)
1844 		ath11k_warn(ar->ab, "failed to set mgmt tx rate %d\n", ret);
1845 
1846 	vdev_param = WMI_VDEV_PARAM_BEACON_RATE;
1847 	ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id, vdev_param,
1848 					    hw_rate_code);
1849 	if (ret)
1850 		ath11k_warn(ar->ab, "failed to set beacon tx rate %d\n", ret);
1851 }
1852 
1853 static void ath11k_mac_op_bss_info_changed(struct ieee80211_hw *hw,
1854 					   struct ieee80211_vif *vif,
1855 					   struct ieee80211_bss_conf *info,
1856 					   u32 changed)
1857 {
1858 	struct ath11k *ar = hw->priv;
1859 	struct ath11k_vif *arvif = ath11k_vif_to_arvif(vif);
1860 	struct cfg80211_chan_def def;
1861 	u32 param_id, param_value;
1862 	enum nl80211_band band;
1863 	u32 vdev_param;
1864 	int mcast_rate;
1865 	u32 preamble;
1866 	u16 hw_value;
1867 	u16 bitrate;
1868 	int ret = 0;
1869 	u8 rateidx;
1870 	u32 rate;
1871 
1872 	mutex_lock(&ar->conf_mutex);
1873 
1874 	if (changed & BSS_CHANGED_BEACON_INT) {
1875 		arvif->beacon_interval = info->beacon_int;
1876 
1877 		param_id = WMI_VDEV_PARAM_BEACON_INTERVAL;
1878 		ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
1879 						    param_id,
1880 						    arvif->beacon_interval);
1881 		if (ret)
1882 			ath11k_warn(ar->ab, "Failed to set beacon interval for VDEV: %d\n",
1883 				    arvif->vdev_id);
1884 		else
1885 			ath11k_dbg(ar->ab, ATH11K_DBG_MAC,
1886 				   "Beacon interval: %d set for VDEV: %d\n",
1887 				   arvif->beacon_interval, arvif->vdev_id);
1888 	}
1889 
1890 	if (changed & BSS_CHANGED_BEACON) {
1891 		param_id = WMI_PDEV_PARAM_BEACON_TX_MODE;
1892 		param_value = WMI_BEACON_STAGGERED_MODE;
1893 		ret = ath11k_wmi_pdev_set_param(ar, param_id,
1894 						param_value, ar->pdev->pdev_id);
1895 		if (ret)
1896 			ath11k_warn(ar->ab, "Failed to set beacon mode for VDEV: %d\n",
1897 				    arvif->vdev_id);
1898 		else
1899 			ath11k_dbg(ar->ab, ATH11K_DBG_MAC,
1900 				   "Set staggered beacon mode for VDEV: %d\n",
1901 				   arvif->vdev_id);
1902 
1903 		ret = ath11k_mac_setup_bcn_tmpl(arvif);
1904 		if (ret)
1905 			ath11k_warn(ar->ab, "failed to update bcn template: %d\n",
1906 				    ret);
1907 
1908 		if (vif->bss_conf.he_support) {
1909 			ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
1910 							    WMI_VDEV_PARAM_BA_MODE,
1911 							    WMI_BA_MODE_BUFFER_SIZE_256);
1912 			if (ret)
1913 				ath11k_warn(ar->ab,
1914 					    "failed to set BA BUFFER SIZE 256 for vdev: %d\n",
1915 					    arvif->vdev_id);
1916 			else
1917 				ath11k_dbg(ar->ab, ATH11K_DBG_MAC,
1918 					   "Set BA BUFFER SIZE 256 for VDEV: %d\n",
1919 					   arvif->vdev_id);
1920 		}
1921 	}
1922 
1923 	if (changed & (BSS_CHANGED_BEACON_INFO | BSS_CHANGED_BEACON)) {
1924 		arvif->dtim_period = info->dtim_period;
1925 
1926 		param_id = WMI_VDEV_PARAM_DTIM_PERIOD;
1927 		ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
1928 						    param_id,
1929 						    arvif->dtim_period);
1930 
1931 		if (ret)
1932 			ath11k_warn(ar->ab, "Failed to set dtim period for VDEV %d: %i\n",
1933 				    arvif->vdev_id, ret);
1934 		else
1935 			ath11k_dbg(ar->ab, ATH11K_DBG_MAC,
1936 				   "DTIM period: %d set for VDEV: %d\n",
1937 				   arvif->dtim_period, arvif->vdev_id);
1938 	}
1939 
1940 	if (changed & BSS_CHANGED_SSID &&
1941 	    vif->type == NL80211_IFTYPE_AP) {
1942 		arvif->u.ap.ssid_len = info->ssid_len;
1943 		if (info->ssid_len)
1944 			memcpy(arvif->u.ap.ssid, info->ssid, info->ssid_len);
1945 		arvif->u.ap.hidden_ssid = info->hidden_ssid;
1946 	}
1947 
1948 	if (changed & BSS_CHANGED_BSSID && !is_zero_ether_addr(info->bssid))
1949 		ether_addr_copy(arvif->bssid, info->bssid);
1950 
1951 	if (changed & BSS_CHANGED_BEACON_ENABLED)
1952 		ath11k_control_beaconing(arvif, info);
1953 
1954 	if (changed & BSS_CHANGED_ERP_CTS_PROT) {
1955 		u32 cts_prot;
1956 
1957 		cts_prot = !!(info->use_cts_prot);
1958 		param_id = WMI_VDEV_PARAM_PROTECTION_MODE;
1959 
1960 		if (arvif->is_started) {
1961 			ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
1962 							    param_id, cts_prot);
1963 			if (ret)
1964 				ath11k_warn(ar->ab, "Failed to set CTS prot for VDEV: %d\n",
1965 					    arvif->vdev_id);
1966 			else
1967 				ath11k_dbg(ar->ab, ATH11K_DBG_MAC, "Set CTS prot: %d for VDEV: %d\n",
1968 					   cts_prot, arvif->vdev_id);
1969 		} else {
1970 			ath11k_dbg(ar->ab, ATH11K_DBG_MAC, "defer protection mode setup, vdev is not ready yet\n");
1971 		}
1972 	}
1973 
1974 	if (changed & BSS_CHANGED_ERP_SLOT) {
1975 		u32 slottime;
1976 
1977 		if (info->use_short_slot)
1978 			slottime = WMI_VDEV_SLOT_TIME_SHORT; /* 9us */
1979 
1980 		else
1981 			slottime = WMI_VDEV_SLOT_TIME_LONG; /* 20us */
1982 
1983 		param_id = WMI_VDEV_PARAM_SLOT_TIME;
1984 		ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
1985 						    param_id, slottime);
1986 		if (ret)
1987 			ath11k_warn(ar->ab, "Failed to set erp slot for VDEV: %d\n",
1988 				    arvif->vdev_id);
1989 		else
1990 			ath11k_dbg(ar->ab, ATH11K_DBG_MAC,
1991 				   "Set slottime: %d for VDEV: %d\n",
1992 				   slottime, arvif->vdev_id);
1993 	}
1994 
1995 	if (changed & BSS_CHANGED_ERP_PREAMBLE) {
1996 		u32 preamble;
1997 
1998 		if (info->use_short_preamble)
1999 			preamble = WMI_VDEV_PREAMBLE_SHORT;
2000 		else
2001 			preamble = WMI_VDEV_PREAMBLE_LONG;
2002 
2003 		param_id = WMI_VDEV_PARAM_PREAMBLE;
2004 		ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
2005 						    param_id, preamble);
2006 		if (ret)
2007 			ath11k_warn(ar->ab, "Failed to set preamble for VDEV: %d\n",
2008 				    arvif->vdev_id);
2009 		else
2010 			ath11k_dbg(ar->ab, ATH11K_DBG_MAC,
2011 				   "Set preamble: %d for VDEV: %d\n",
2012 				   preamble, arvif->vdev_id);
2013 	}
2014 
2015 	if (changed & BSS_CHANGED_ASSOC) {
2016 		if (info->assoc)
2017 			ath11k_bss_assoc(hw, vif, info);
2018 		else
2019 			ath11k_bss_disassoc(hw, vif);
2020 	}
2021 
2022 	if (changed & BSS_CHANGED_TXPOWER) {
2023 		ath11k_dbg(ar->ab, ATH11K_DBG_MAC, "mac vdev_id %i txpower %d\n",
2024 			   arvif->vdev_id, info->txpower);
2025 
2026 		arvif->txpower = info->txpower;
2027 		ath11k_mac_txpower_recalc(ar);
2028 	}
2029 
2030 	if (changed & BSS_CHANGED_MCAST_RATE &&
2031 	    !ath11k_mac_vif_chan(arvif->vif, &def)) {
2032 		band = def.chan->band;
2033 		mcast_rate = vif->bss_conf.mcast_rate[band];
2034 
2035 		if (mcast_rate > 0)
2036 			rateidx = mcast_rate - 1;
2037 		else
2038 			rateidx = ffs(vif->bss_conf.basic_rates) - 1;
2039 
2040 		if (ar->pdev->cap.supported_bands & WMI_HOST_WLAN_5G_CAP)
2041 			rateidx += ATH11K_MAC_FIRST_OFDM_RATE_IDX;
2042 
2043 		bitrate = ath11k_legacy_rates[rateidx].bitrate;
2044 		hw_value = ath11k_legacy_rates[rateidx].hw_value;
2045 
2046 		if (ath11k_mac_bitrate_is_cck(bitrate))
2047 			preamble = WMI_RATE_PREAMBLE_CCK;
2048 		else
2049 			preamble = WMI_RATE_PREAMBLE_OFDM;
2050 
2051 		rate = ATH11K_HW_RATE_CODE(hw_value, 0, preamble);
2052 
2053 		ath11k_dbg(ar->ab, ATH11K_DBG_MAC,
2054 			   "mac vdev %d mcast_rate %x\n",
2055 			   arvif->vdev_id, rate);
2056 
2057 		vdev_param = WMI_VDEV_PARAM_MCAST_DATA_RATE;
2058 		ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
2059 						    vdev_param, rate);
2060 		if (ret)
2061 			ath11k_warn(ar->ab,
2062 				    "failed to set mcast rate on vdev %i: %d\n",
2063 				    arvif->vdev_id,  ret);
2064 
2065 		vdev_param = WMI_VDEV_PARAM_BCAST_DATA_RATE;
2066 		ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
2067 						    vdev_param, rate);
2068 		if (ret)
2069 			ath11k_warn(ar->ab,
2070 				    "failed to set bcast rate on vdev %i: %d\n",
2071 				    arvif->vdev_id,  ret);
2072 	}
2073 
2074 	if (changed & BSS_CHANGED_BASIC_RATES &&
2075 	    !ath11k_mac_vif_chan(arvif->vif, &def))
2076 		ath11k_recalculate_mgmt_rate(ar, vif, &def);
2077 
2078 	if (changed & BSS_CHANGED_TWT) {
2079 		if (info->twt_requester || info->twt_responder)
2080 			ath11k_wmi_send_twt_enable_cmd(ar, ar->pdev->pdev_id);
2081 		else
2082 			ath11k_wmi_send_twt_disable_cmd(ar, ar->pdev->pdev_id);
2083 	}
2084 
2085 	if (changed & BSS_CHANGED_HE_OBSS_PD)
2086 		ath11k_wmi_send_obss_spr_cmd(ar, arvif->vdev_id,
2087 					     &info->he_obss_pd);
2088 
2089 	if (changed & BSS_CHANGED_HE_BSS_COLOR) {
2090 		if (vif->type == NL80211_IFTYPE_AP) {
2091 			ret = ath11k_wmi_send_obss_color_collision_cfg_cmd(
2092 				ar, arvif->vdev_id, info->he_bss_color.color,
2093 				ATH11K_BSS_COLOR_COLLISION_DETECTION_AP_PERIOD_MS,
2094 				info->he_bss_color.enabled);
2095 			if (ret)
2096 				ath11k_warn(ar->ab, "failed to set bss color collision on vdev %i: %d\n",
2097 					    arvif->vdev_id,  ret);
2098 		} else if (vif->type == NL80211_IFTYPE_STATION) {
2099 			ret = ath11k_wmi_send_bss_color_change_enable_cmd(ar,
2100 									  arvif->vdev_id,
2101 									  1);
2102 			if (ret)
2103 				ath11k_warn(ar->ab, "failed to enable bss color change on vdev %i: %d\n",
2104 					    arvif->vdev_id,  ret);
2105 			ret = ath11k_wmi_send_obss_color_collision_cfg_cmd(
2106 				ar, arvif->vdev_id, 0,
2107 				ATH11K_BSS_COLOR_COLLISION_DETECTION_STA_PERIOD_MS, 1);
2108 			if (ret)
2109 				ath11k_warn(ar->ab, "failed to set bss color collision on vdev %i: %d\n",
2110 					    arvif->vdev_id,  ret);
2111 		}
2112 	}
2113 
2114 	mutex_unlock(&ar->conf_mutex);
2115 }
2116 
2117 void __ath11k_mac_scan_finish(struct ath11k *ar)
2118 {
2119 	lockdep_assert_held(&ar->data_lock);
2120 
2121 	switch (ar->scan.state) {
2122 	case ATH11K_SCAN_IDLE:
2123 		break;
2124 	case ATH11K_SCAN_RUNNING:
2125 	case ATH11K_SCAN_ABORTING:
2126 		if (!ar->scan.is_roc) {
2127 			struct cfg80211_scan_info info = {
2128 				.aborted = (ar->scan.state ==
2129 					    ATH11K_SCAN_ABORTING),
2130 			};
2131 
2132 			ieee80211_scan_completed(ar->hw, &info);
2133 		} else if (ar->scan.roc_notify) {
2134 			ieee80211_remain_on_channel_expired(ar->hw);
2135 		}
2136 		fallthrough;
2137 	case ATH11K_SCAN_STARTING:
2138 		ar->scan.state = ATH11K_SCAN_IDLE;
2139 		ar->scan_channel = NULL;
2140 		ar->scan.roc_freq = 0;
2141 		cancel_delayed_work(&ar->scan.timeout);
2142 		complete(&ar->scan.completed);
2143 		break;
2144 	}
2145 }
2146 
2147 void ath11k_mac_scan_finish(struct ath11k *ar)
2148 {
2149 	spin_lock_bh(&ar->data_lock);
2150 	__ath11k_mac_scan_finish(ar);
2151 	spin_unlock_bh(&ar->data_lock);
2152 }
2153 
2154 static int ath11k_scan_stop(struct ath11k *ar)
2155 {
2156 	struct scan_cancel_param arg = {
2157 		.req_type = WLAN_SCAN_CANCEL_SINGLE,
2158 		.scan_id = ATH11K_SCAN_ID,
2159 	};
2160 	int ret;
2161 
2162 	lockdep_assert_held(&ar->conf_mutex);
2163 
2164 	/* TODO: Fill other STOP Params */
2165 	arg.pdev_id = ar->pdev->pdev_id;
2166 
2167 	ret = ath11k_wmi_send_scan_stop_cmd(ar, &arg);
2168 	if (ret) {
2169 		ath11k_warn(ar->ab, "failed to stop wmi scan: %d\n", ret);
2170 		goto out;
2171 	}
2172 
2173 	ret = wait_for_completion_timeout(&ar->scan.completed, 3 * HZ);
2174 	if (ret == 0) {
2175 		ath11k_warn(ar->ab,
2176 			    "failed to receive scan abort comple: timed out\n");
2177 		ret = -ETIMEDOUT;
2178 	} else if (ret > 0) {
2179 		ret = 0;
2180 	}
2181 
2182 out:
2183 	/* Scan state should be updated upon scan completion but in case
2184 	 * firmware fails to deliver the event (for whatever reason) it is
2185 	 * desired to clean up scan state anyway. Firmware may have just
2186 	 * dropped the scan completion event delivery due to transport pipe
2187 	 * being overflown with data and/or it can recover on its own before
2188 	 * next scan request is submitted.
2189 	 */
2190 	spin_lock_bh(&ar->data_lock);
2191 	if (ar->scan.state != ATH11K_SCAN_IDLE)
2192 		__ath11k_mac_scan_finish(ar);
2193 	spin_unlock_bh(&ar->data_lock);
2194 
2195 	return ret;
2196 }
2197 
2198 static void ath11k_scan_abort(struct ath11k *ar)
2199 {
2200 	int ret;
2201 
2202 	lockdep_assert_held(&ar->conf_mutex);
2203 
2204 	spin_lock_bh(&ar->data_lock);
2205 
2206 	switch (ar->scan.state) {
2207 	case ATH11K_SCAN_IDLE:
2208 		/* This can happen if timeout worker kicked in and called
2209 		 * abortion while scan completion was being processed.
2210 		 */
2211 		break;
2212 	case ATH11K_SCAN_STARTING:
2213 	case ATH11K_SCAN_ABORTING:
2214 		ath11k_warn(ar->ab, "refusing scan abortion due to invalid scan state: %d\n",
2215 			    ar->scan.state);
2216 		break;
2217 	case ATH11K_SCAN_RUNNING:
2218 		ar->scan.state = ATH11K_SCAN_ABORTING;
2219 		spin_unlock_bh(&ar->data_lock);
2220 
2221 		ret = ath11k_scan_stop(ar);
2222 		if (ret)
2223 			ath11k_warn(ar->ab, "failed to abort scan: %d\n", ret);
2224 
2225 		spin_lock_bh(&ar->data_lock);
2226 		break;
2227 	}
2228 
2229 	spin_unlock_bh(&ar->data_lock);
2230 }
2231 
2232 static void ath11k_scan_timeout_work(struct work_struct *work)
2233 {
2234 	struct ath11k *ar = container_of(work, struct ath11k,
2235 					 scan.timeout.work);
2236 
2237 	mutex_lock(&ar->conf_mutex);
2238 	ath11k_scan_abort(ar);
2239 	mutex_unlock(&ar->conf_mutex);
2240 }
2241 
2242 static int ath11k_start_scan(struct ath11k *ar,
2243 			     struct scan_req_params *arg)
2244 {
2245 	int ret;
2246 
2247 	lockdep_assert_held(&ar->conf_mutex);
2248 
2249 	if (ath11k_spectral_get_mode(ar) == ATH11K_SPECTRAL_BACKGROUND)
2250 		ath11k_spectral_reset_buffer(ar);
2251 
2252 	ret = ath11k_wmi_send_scan_start_cmd(ar, arg);
2253 	if (ret)
2254 		return ret;
2255 
2256 	ret = wait_for_completion_timeout(&ar->scan.started, 1 * HZ);
2257 	if (ret == 0) {
2258 		ret = ath11k_scan_stop(ar);
2259 		if (ret)
2260 			ath11k_warn(ar->ab, "failed to stop scan: %d\n", ret);
2261 
2262 		return -ETIMEDOUT;
2263 	}
2264 
2265 	/* If we failed to start the scan, return error code at
2266 	 * this point.  This is probably due to some issue in the
2267 	 * firmware, but no need to wedge the driver due to that...
2268 	 */
2269 	spin_lock_bh(&ar->data_lock);
2270 	if (ar->scan.state == ATH11K_SCAN_IDLE) {
2271 		spin_unlock_bh(&ar->data_lock);
2272 		return -EINVAL;
2273 	}
2274 	spin_unlock_bh(&ar->data_lock);
2275 
2276 	return 0;
2277 }
2278 
2279 static int ath11k_mac_op_hw_scan(struct ieee80211_hw *hw,
2280 				 struct ieee80211_vif *vif,
2281 				 struct ieee80211_scan_request *hw_req)
2282 {
2283 	struct ath11k *ar = hw->priv;
2284 	struct ath11k_vif *arvif = ath11k_vif_to_arvif(vif);
2285 	struct cfg80211_scan_request *req = &hw_req->req;
2286 	struct scan_req_params arg;
2287 	int ret = 0;
2288 	int i;
2289 
2290 	mutex_lock(&ar->conf_mutex);
2291 
2292 	spin_lock_bh(&ar->data_lock);
2293 	switch (ar->scan.state) {
2294 	case ATH11K_SCAN_IDLE:
2295 		reinit_completion(&ar->scan.started);
2296 		reinit_completion(&ar->scan.completed);
2297 		ar->scan.state = ATH11K_SCAN_STARTING;
2298 		ar->scan.is_roc = false;
2299 		ar->scan.vdev_id = arvif->vdev_id;
2300 		ret = 0;
2301 		break;
2302 	case ATH11K_SCAN_STARTING:
2303 	case ATH11K_SCAN_RUNNING:
2304 	case ATH11K_SCAN_ABORTING:
2305 		ret = -EBUSY;
2306 		break;
2307 	}
2308 	spin_unlock_bh(&ar->data_lock);
2309 
2310 	if (ret)
2311 		goto exit;
2312 
2313 	memset(&arg, 0, sizeof(arg));
2314 	ath11k_wmi_start_scan_init(ar, &arg);
2315 	arg.vdev_id = arvif->vdev_id;
2316 	arg.scan_id = ATH11K_SCAN_ID;
2317 
2318 	if (req->ie_len) {
2319 		arg.extraie.len = req->ie_len;
2320 		arg.extraie.ptr = kzalloc(req->ie_len, GFP_KERNEL);
2321 		memcpy(arg.extraie.ptr, req->ie, req->ie_len);
2322 	}
2323 
2324 	if (req->n_ssids) {
2325 		arg.num_ssids = req->n_ssids;
2326 		for (i = 0; i < arg.num_ssids; i++) {
2327 			arg.ssid[i].length  = req->ssids[i].ssid_len;
2328 			memcpy(&arg.ssid[i].ssid, req->ssids[i].ssid,
2329 			       req->ssids[i].ssid_len);
2330 		}
2331 	} else {
2332 		arg.scan_flags |= WMI_SCAN_FLAG_PASSIVE;
2333 	}
2334 
2335 	if (req->n_channels) {
2336 		arg.num_chan = req->n_channels;
2337 		for (i = 0; i < arg.num_chan; i++)
2338 			arg.chan_list[i] = req->channels[i]->center_freq;
2339 	}
2340 
2341 	ret = ath11k_start_scan(ar, &arg);
2342 	if (ret) {
2343 		ath11k_warn(ar->ab, "failed to start hw scan: %d\n", ret);
2344 		spin_lock_bh(&ar->data_lock);
2345 		ar->scan.state = ATH11K_SCAN_IDLE;
2346 		spin_unlock_bh(&ar->data_lock);
2347 	}
2348 
2349 	/* Add a 200ms margin to account for event/command processing */
2350 	ieee80211_queue_delayed_work(ar->hw, &ar->scan.timeout,
2351 				     msecs_to_jiffies(arg.max_scan_time +
2352 						      ATH11K_MAC_SCAN_TIMEOUT_MSECS));
2353 
2354 exit:
2355 	if (req->ie_len)
2356 		kfree(arg.extraie.ptr);
2357 
2358 	mutex_unlock(&ar->conf_mutex);
2359 	return ret;
2360 }
2361 
2362 static void ath11k_mac_op_cancel_hw_scan(struct ieee80211_hw *hw,
2363 					 struct ieee80211_vif *vif)
2364 {
2365 	struct ath11k *ar = hw->priv;
2366 
2367 	mutex_lock(&ar->conf_mutex);
2368 	ath11k_scan_abort(ar);
2369 	mutex_unlock(&ar->conf_mutex);
2370 
2371 	cancel_delayed_work_sync(&ar->scan.timeout);
2372 }
2373 
2374 static int ath11k_install_key(struct ath11k_vif *arvif,
2375 			      struct ieee80211_key_conf *key,
2376 			      enum set_key_cmd cmd,
2377 			      const u8 *macaddr, u32 flags)
2378 {
2379 	int ret;
2380 	struct ath11k *ar = arvif->ar;
2381 	struct wmi_vdev_install_key_arg arg = {
2382 		.vdev_id = arvif->vdev_id,
2383 		.key_idx = key->keyidx,
2384 		.key_len = key->keylen,
2385 		.key_data = key->key,
2386 		.key_flags = flags,
2387 		.macaddr = macaddr,
2388 	};
2389 
2390 	lockdep_assert_held(&arvif->ar->conf_mutex);
2391 
2392 	reinit_completion(&ar->install_key_done);
2393 
2394 	if (test_bit(ATH11K_FLAG_HW_CRYPTO_DISABLED, &ar->ab->dev_flags))
2395 		return 0;
2396 
2397 	if (cmd == DISABLE_KEY) {
2398 		/* TODO: Check if FW expects  value other than NONE for del */
2399 		/* arg.key_cipher = WMI_CIPHER_NONE; */
2400 		arg.key_len = 0;
2401 		arg.key_data = NULL;
2402 		goto install;
2403 	}
2404 
2405 	switch (key->cipher) {
2406 	case WLAN_CIPHER_SUITE_CCMP:
2407 		arg.key_cipher = WMI_CIPHER_AES_CCM;
2408 		/* TODO: Re-check if flag is valid */
2409 		key->flags |= IEEE80211_KEY_FLAG_GENERATE_IV_MGMT;
2410 		break;
2411 	case WLAN_CIPHER_SUITE_TKIP:
2412 		arg.key_cipher = WMI_CIPHER_TKIP;
2413 		arg.key_txmic_len = 8;
2414 		arg.key_rxmic_len = 8;
2415 		break;
2416 	case WLAN_CIPHER_SUITE_CCMP_256:
2417 		arg.key_cipher = WMI_CIPHER_AES_CCM;
2418 		break;
2419 	case WLAN_CIPHER_SUITE_GCMP:
2420 	case WLAN_CIPHER_SUITE_GCMP_256:
2421 		arg.key_cipher = WMI_CIPHER_AES_GCM;
2422 		break;
2423 	default:
2424 		ath11k_warn(ar->ab, "cipher %d is not supported\n", key->cipher);
2425 		return -EOPNOTSUPP;
2426 	}
2427 
2428 	if (test_bit(ATH11K_FLAG_RAW_MODE, &ar->ab->dev_flags))
2429 		key->flags |= IEEE80211_KEY_FLAG_GENERATE_IV |
2430 			      IEEE80211_KEY_FLAG_RESERVE_TAILROOM;
2431 
2432 install:
2433 	ret = ath11k_wmi_vdev_install_key(arvif->ar, &arg);
2434 
2435 	if (ret)
2436 		return ret;
2437 
2438 	if (!wait_for_completion_timeout(&ar->install_key_done, 1 * HZ))
2439 		return -ETIMEDOUT;
2440 
2441 	return ar->install_key_status ? -EINVAL : 0;
2442 }
2443 
2444 static int ath11k_clear_peer_keys(struct ath11k_vif *arvif,
2445 				  const u8 *addr)
2446 {
2447 	struct ath11k *ar = arvif->ar;
2448 	struct ath11k_base *ab = ar->ab;
2449 	struct ath11k_peer *peer;
2450 	int first_errno = 0;
2451 	int ret;
2452 	int i;
2453 	u32 flags = 0;
2454 
2455 	lockdep_assert_held(&ar->conf_mutex);
2456 
2457 	spin_lock_bh(&ab->base_lock);
2458 	peer = ath11k_peer_find(ab, arvif->vdev_id, addr);
2459 	spin_unlock_bh(&ab->base_lock);
2460 
2461 	if (!peer)
2462 		return -ENOENT;
2463 
2464 	for (i = 0; i < ARRAY_SIZE(peer->keys); i++) {
2465 		if (!peer->keys[i])
2466 			continue;
2467 
2468 		/* key flags are not required to delete the key */
2469 		ret = ath11k_install_key(arvif, peer->keys[i],
2470 					 DISABLE_KEY, addr, flags);
2471 		if (ret < 0 && first_errno == 0)
2472 			first_errno = ret;
2473 
2474 		if (ret < 0)
2475 			ath11k_warn(ab, "failed to remove peer key %d: %d\n",
2476 				    i, ret);
2477 
2478 		spin_lock_bh(&ab->base_lock);
2479 		peer->keys[i] = NULL;
2480 		spin_unlock_bh(&ab->base_lock);
2481 	}
2482 
2483 	return first_errno;
2484 }
2485 
2486 static int ath11k_mac_op_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd,
2487 				 struct ieee80211_vif *vif, struct ieee80211_sta *sta,
2488 				 struct ieee80211_key_conf *key)
2489 {
2490 	struct ath11k *ar = hw->priv;
2491 	struct ath11k_base *ab = ar->ab;
2492 	struct ath11k_vif *arvif = ath11k_vif_to_arvif(vif);
2493 	struct ath11k_peer *peer;
2494 	struct ath11k_sta *arsta;
2495 	const u8 *peer_addr;
2496 	int ret = 0;
2497 	u32 flags = 0;
2498 
2499 	/* BIP needs to be done in software */
2500 	if (key->cipher == WLAN_CIPHER_SUITE_AES_CMAC ||
2501 	    key->cipher == WLAN_CIPHER_SUITE_BIP_GMAC_128 ||
2502 	    key->cipher == WLAN_CIPHER_SUITE_BIP_GMAC_256 ||
2503 	    key->cipher == WLAN_CIPHER_SUITE_BIP_CMAC_256)
2504 		return 1;
2505 
2506 	if (test_bit(ATH11K_FLAG_HW_CRYPTO_DISABLED, &ar->ab->dev_flags))
2507 		return 1;
2508 
2509 	if (key->keyidx > WMI_MAX_KEY_INDEX)
2510 		return -ENOSPC;
2511 
2512 	mutex_lock(&ar->conf_mutex);
2513 
2514 	if (sta)
2515 		peer_addr = sta->addr;
2516 	else if (arvif->vdev_type == WMI_VDEV_TYPE_STA)
2517 		peer_addr = vif->bss_conf.bssid;
2518 	else
2519 		peer_addr = vif->addr;
2520 
2521 	key->hw_key_idx = key->keyidx;
2522 
2523 	/* the peer should not disappear in mid-way (unless FW goes awry) since
2524 	 * we already hold conf_mutex. we just make sure its there now.
2525 	 */
2526 	spin_lock_bh(&ab->base_lock);
2527 	peer = ath11k_peer_find(ab, arvif->vdev_id, peer_addr);
2528 	spin_unlock_bh(&ab->base_lock);
2529 
2530 	if (!peer) {
2531 		if (cmd == SET_KEY) {
2532 			ath11k_warn(ab, "cannot install key for non-existent peer %pM\n",
2533 				    peer_addr);
2534 			ret = -EOPNOTSUPP;
2535 			goto exit;
2536 		} else {
2537 			/* if the peer doesn't exist there is no key to disable
2538 			 * anymore
2539 			 */
2540 			goto exit;
2541 		}
2542 	}
2543 
2544 	if (key->flags & IEEE80211_KEY_FLAG_PAIRWISE)
2545 		flags |= WMI_KEY_PAIRWISE;
2546 	else
2547 		flags |= WMI_KEY_GROUP;
2548 
2549 	ret = ath11k_install_key(arvif, key, cmd, peer_addr, flags);
2550 	if (ret) {
2551 		ath11k_warn(ab, "ath11k_install_key failed (%d)\n", ret);
2552 		goto exit;
2553 	}
2554 
2555 	ret = ath11k_dp_peer_rx_pn_replay_config(arvif, peer_addr, cmd, key);
2556 	if (ret) {
2557 		ath11k_warn(ab, "failed to offload PN replay detection %d\n", ret);
2558 		goto exit;
2559 	}
2560 
2561 	spin_lock_bh(&ab->base_lock);
2562 	peer = ath11k_peer_find(ab, arvif->vdev_id, peer_addr);
2563 	if (peer && cmd == SET_KEY) {
2564 		peer->keys[key->keyidx] = key;
2565 		if (key->flags & IEEE80211_KEY_FLAG_PAIRWISE) {
2566 			peer->ucast_keyidx = key->keyidx;
2567 			peer->sec_type = ath11k_dp_tx_get_encrypt_type(key->cipher);
2568 		} else {
2569 			peer->mcast_keyidx = key->keyidx;
2570 			peer->sec_type_grp = ath11k_dp_tx_get_encrypt_type(key->cipher);
2571 		}
2572 	} else if (peer && cmd == DISABLE_KEY) {
2573 		peer->keys[key->keyidx] = NULL;
2574 		if (key->flags & IEEE80211_KEY_FLAG_PAIRWISE)
2575 			peer->ucast_keyidx = 0;
2576 		else
2577 			peer->mcast_keyidx = 0;
2578 	} else if (!peer)
2579 		/* impossible unless FW goes crazy */
2580 		ath11k_warn(ab, "peer %pM disappeared!\n", peer_addr);
2581 
2582 	if (sta) {
2583 		arsta = (struct ath11k_sta *)sta->drv_priv;
2584 
2585 		switch (key->cipher) {
2586 		case WLAN_CIPHER_SUITE_TKIP:
2587 		case WLAN_CIPHER_SUITE_CCMP:
2588 		case WLAN_CIPHER_SUITE_CCMP_256:
2589 		case WLAN_CIPHER_SUITE_GCMP:
2590 		case WLAN_CIPHER_SUITE_GCMP_256:
2591 			if (cmd == SET_KEY)
2592 				arsta->pn_type = HAL_PN_TYPE_WPA;
2593 			else
2594 				arsta->pn_type = HAL_PN_TYPE_NONE;
2595 			break;
2596 		default:
2597 			arsta->pn_type = HAL_PN_TYPE_NONE;
2598 			break;
2599 		}
2600 	}
2601 
2602 	spin_unlock_bh(&ab->base_lock);
2603 
2604 exit:
2605 	mutex_unlock(&ar->conf_mutex);
2606 	return ret;
2607 }
2608 
2609 static int
2610 ath11k_mac_bitrate_mask_num_vht_rates(struct ath11k *ar,
2611 				      enum nl80211_band band,
2612 				      const struct cfg80211_bitrate_mask *mask)
2613 {
2614 	int num_rates = 0;
2615 	int i;
2616 
2617 	for (i = 0; i < ARRAY_SIZE(mask->control[band].vht_mcs); i++)
2618 		num_rates += hweight16(mask->control[band].vht_mcs[i]);
2619 
2620 	return num_rates;
2621 }
2622 
2623 static int
2624 ath11k_mac_set_peer_vht_fixed_rate(struct ath11k_vif *arvif,
2625 				   struct ieee80211_sta *sta,
2626 				   const struct cfg80211_bitrate_mask *mask,
2627 				   enum nl80211_band band)
2628 {
2629 	struct ath11k *ar = arvif->ar;
2630 	u8 vht_rate, nss;
2631 	u32 rate_code;
2632 	int ret, i;
2633 
2634 	lockdep_assert_held(&ar->conf_mutex);
2635 
2636 	nss = 0;
2637 
2638 	for (i = 0; i < ARRAY_SIZE(mask->control[band].vht_mcs); i++) {
2639 		if (hweight16(mask->control[band].vht_mcs[i]) == 1) {
2640 			nss = i + 1;
2641 			vht_rate = ffs(mask->control[band].vht_mcs[i]) - 1;
2642 		}
2643 	}
2644 
2645 	if (!nss) {
2646 		ath11k_warn(ar->ab, "No single VHT Fixed rate found to set for %pM",
2647 			    sta->addr);
2648 		return -EINVAL;
2649 	}
2650 
2651 	ath11k_dbg(ar->ab, ATH11K_DBG_MAC,
2652 		   "Setting Fixed VHT Rate for peer %pM. Device will not switch to any other selected rates",
2653 		   sta->addr);
2654 
2655 	rate_code = ATH11K_HW_RATE_CODE(vht_rate, nss - 1,
2656 					WMI_RATE_PREAMBLE_VHT);
2657 	ret = ath11k_wmi_set_peer_param(ar, sta->addr,
2658 					arvif->vdev_id,
2659 					WMI_PEER_PARAM_FIXED_RATE,
2660 					rate_code);
2661 	if (ret)
2662 		ath11k_warn(ar->ab,
2663 			    "failed to update STA %pM Fixed Rate %d: %d\n",
2664 			     sta->addr, rate_code, ret);
2665 
2666 	return ret;
2667 }
2668 
2669 static int ath11k_station_assoc(struct ath11k *ar,
2670 				struct ieee80211_vif *vif,
2671 				struct ieee80211_sta *sta,
2672 				bool reassoc)
2673 {
2674 	struct ath11k_vif *arvif = ath11k_vif_to_arvif(vif);
2675 	struct peer_assoc_params peer_arg;
2676 	int ret = 0;
2677 	struct cfg80211_chan_def def;
2678 	enum nl80211_band band;
2679 	struct cfg80211_bitrate_mask *mask;
2680 	u8 num_vht_rates;
2681 
2682 	lockdep_assert_held(&ar->conf_mutex);
2683 
2684 	if (WARN_ON(ath11k_mac_vif_chan(vif, &def)))
2685 		return -EPERM;
2686 
2687 	band = def.chan->band;
2688 	mask = &arvif->bitrate_mask;
2689 
2690 	ath11k_peer_assoc_prepare(ar, vif, sta, &peer_arg, reassoc);
2691 
2692 	ret = ath11k_wmi_send_peer_assoc_cmd(ar, &peer_arg);
2693 	if (ret) {
2694 		ath11k_warn(ar->ab, "failed to run peer assoc for STA %pM vdev %i: %d\n",
2695 			    sta->addr, arvif->vdev_id, ret);
2696 		return ret;
2697 	}
2698 
2699 	if (!wait_for_completion_timeout(&ar->peer_assoc_done, 1 * HZ)) {
2700 		ath11k_warn(ar->ab, "failed to get peer assoc conf event for %pM vdev %i\n",
2701 			    sta->addr, arvif->vdev_id);
2702 		return -ETIMEDOUT;
2703 	}
2704 
2705 	num_vht_rates = ath11k_mac_bitrate_mask_num_vht_rates(ar, band, mask);
2706 
2707 	/* If single VHT rate is configured (by set_bitrate_mask()),
2708 	 * peer_assoc will disable VHT. This is now enabled by a peer specific
2709 	 * fixed param.
2710 	 * Note that all other rates and NSS will be disabled for this peer.
2711 	 */
2712 	if (sta->vht_cap.vht_supported && num_vht_rates == 1) {
2713 		ret = ath11k_mac_set_peer_vht_fixed_rate(arvif, sta, mask,
2714 							 band);
2715 		if (ret)
2716 			return ret;
2717 	}
2718 
2719 	/* Re-assoc is run only to update supported rates for given station. It
2720 	 * doesn't make much sense to reconfigure the peer completely.
2721 	 */
2722 	if (reassoc)
2723 		return 0;
2724 
2725 	ret = ath11k_setup_peer_smps(ar, arvif, sta->addr,
2726 				     &sta->ht_cap);
2727 	if (ret) {
2728 		ath11k_warn(ar->ab, "failed to setup peer SMPS for vdev %d: %d\n",
2729 			    arvif->vdev_id, ret);
2730 		return ret;
2731 	}
2732 
2733 	if (!sta->wme) {
2734 		arvif->num_legacy_stations++;
2735 		ret = ath11k_recalc_rtscts_prot(arvif);
2736 		if (ret)
2737 			return ret;
2738 	}
2739 
2740 	if (sta->wme && sta->uapsd_queues) {
2741 		ret = ath11k_peer_assoc_qos_ap(ar, arvif, sta);
2742 		if (ret) {
2743 			ath11k_warn(ar->ab, "failed to set qos params for STA %pM for vdev %i: %d\n",
2744 				    sta->addr, arvif->vdev_id, ret);
2745 			return ret;
2746 		}
2747 	}
2748 
2749 	return 0;
2750 }
2751 
2752 static int ath11k_station_disassoc(struct ath11k *ar,
2753 				   struct ieee80211_vif *vif,
2754 				   struct ieee80211_sta *sta)
2755 {
2756 	struct ath11k_vif *arvif = (void *)vif->drv_priv;
2757 	int ret = 0;
2758 
2759 	lockdep_assert_held(&ar->conf_mutex);
2760 
2761 	if (!sta->wme) {
2762 		arvif->num_legacy_stations--;
2763 		ret = ath11k_recalc_rtscts_prot(arvif);
2764 		if (ret)
2765 			return ret;
2766 	}
2767 
2768 	ret = ath11k_clear_peer_keys(arvif, sta->addr);
2769 	if (ret) {
2770 		ath11k_warn(ar->ab, "failed to clear all peer keys for vdev %i: %d\n",
2771 			    arvif->vdev_id, ret);
2772 		return ret;
2773 	}
2774 	return 0;
2775 }
2776 
2777 static void ath11k_sta_rc_update_wk(struct work_struct *wk)
2778 {
2779 	struct ath11k *ar;
2780 	struct ath11k_vif *arvif;
2781 	struct ath11k_sta *arsta;
2782 	struct ieee80211_sta *sta;
2783 	struct cfg80211_chan_def def;
2784 	enum nl80211_band band;
2785 	const u8 *ht_mcs_mask;
2786 	const u16 *vht_mcs_mask;
2787 	u32 changed, bw, nss, smps;
2788 	int err, num_vht_rates;
2789 	const struct cfg80211_bitrate_mask *mask;
2790 	struct peer_assoc_params peer_arg;
2791 
2792 	arsta = container_of(wk, struct ath11k_sta, update_wk);
2793 	sta = container_of((void *)arsta, struct ieee80211_sta, drv_priv);
2794 	arvif = arsta->arvif;
2795 	ar = arvif->ar;
2796 
2797 	if (WARN_ON(ath11k_mac_vif_chan(arvif->vif, &def)))
2798 		return;
2799 
2800 	band = def.chan->band;
2801 	ht_mcs_mask = arvif->bitrate_mask.control[band].ht_mcs;
2802 	vht_mcs_mask = arvif->bitrate_mask.control[band].vht_mcs;
2803 
2804 	spin_lock_bh(&ar->data_lock);
2805 
2806 	changed = arsta->changed;
2807 	arsta->changed = 0;
2808 
2809 	bw = arsta->bw;
2810 	nss = arsta->nss;
2811 	smps = arsta->smps;
2812 
2813 	spin_unlock_bh(&ar->data_lock);
2814 
2815 	mutex_lock(&ar->conf_mutex);
2816 
2817 	nss = max_t(u32, 1, nss);
2818 	nss = min(nss, max(ath11k_mac_max_ht_nss(ht_mcs_mask),
2819 			   ath11k_mac_max_vht_nss(vht_mcs_mask)));
2820 
2821 	if (changed & IEEE80211_RC_BW_CHANGED) {
2822 		err = ath11k_wmi_set_peer_param(ar, sta->addr, arvif->vdev_id,
2823 						WMI_PEER_CHWIDTH, bw);
2824 		if (err)
2825 			ath11k_warn(ar->ab, "failed to update STA %pM peer bw %d: %d\n",
2826 				    sta->addr, bw, err);
2827 	}
2828 
2829 	if (changed & IEEE80211_RC_NSS_CHANGED) {
2830 		ath11k_dbg(ar->ab, ATH11K_DBG_MAC, "mac update sta %pM nss %d\n",
2831 			   sta->addr, nss);
2832 
2833 		err = ath11k_wmi_set_peer_param(ar, sta->addr, arvif->vdev_id,
2834 						WMI_PEER_NSS, nss);
2835 		if (err)
2836 			ath11k_warn(ar->ab, "failed to update STA %pM nss %d: %d\n",
2837 				    sta->addr, nss, err);
2838 	}
2839 
2840 	if (changed & IEEE80211_RC_SMPS_CHANGED) {
2841 		ath11k_dbg(ar->ab, ATH11K_DBG_MAC, "mac update sta %pM smps %d\n",
2842 			   sta->addr, smps);
2843 
2844 		err = ath11k_wmi_set_peer_param(ar, sta->addr, arvif->vdev_id,
2845 						WMI_PEER_MIMO_PS_STATE, smps);
2846 		if (err)
2847 			ath11k_warn(ar->ab, "failed to update STA %pM smps %d: %d\n",
2848 				    sta->addr, smps, err);
2849 	}
2850 
2851 	if (changed & IEEE80211_RC_SUPP_RATES_CHANGED) {
2852 		mask = &arvif->bitrate_mask;
2853 		num_vht_rates = ath11k_mac_bitrate_mask_num_vht_rates(ar, band,
2854 								      mask);
2855 
2856 		/* Peer_assoc_prepare will reject vht rates in
2857 		 * bitrate_mask if its not available in range format and
2858 		 * sets vht tx_rateset as unsupported. So multiple VHT MCS
2859 		 * setting(eg. MCS 4,5,6) per peer is not supported here.
2860 		 * But, Single rate in VHT mask can be set as per-peer
2861 		 * fixed rate. But even if any HT rates are configured in
2862 		 * the bitrate mask, device will not switch to those rates
2863 		 * when per-peer Fixed rate is set.
2864 		 * TODO: Check RATEMASK_CMDID to support auto rates selection
2865 		 * across HT/VHT and for multiple VHT MCS support.
2866 		 */
2867 		if (sta->vht_cap.vht_supported && num_vht_rates == 1) {
2868 			ath11k_mac_set_peer_vht_fixed_rate(arvif, sta, mask,
2869 							   band);
2870 		} else {
2871 			/* If the peer is non-VHT or no fixed VHT rate
2872 			 * is provided in the new bitrate mask we set the
2873 			 * other rates using peer_assoc command.
2874 			 */
2875 			ath11k_peer_assoc_prepare(ar, arvif->vif, sta,
2876 						  &peer_arg, true);
2877 
2878 			err = ath11k_wmi_send_peer_assoc_cmd(ar, &peer_arg);
2879 			if (err)
2880 				ath11k_warn(ar->ab, "failed to run peer assoc for STA %pM vdev %i: %d\n",
2881 					    sta->addr, arvif->vdev_id, err);
2882 
2883 			if (!wait_for_completion_timeout(&ar->peer_assoc_done, 1 * HZ))
2884 				ath11k_warn(ar->ab, "failed to get peer assoc conf event for %pM vdev %i\n",
2885 					    sta->addr, arvif->vdev_id);
2886 		}
2887 	}
2888 
2889 	mutex_unlock(&ar->conf_mutex);
2890 }
2891 
2892 static int ath11k_mac_inc_num_stations(struct ath11k_vif *arvif,
2893 				       struct ieee80211_sta *sta)
2894 {
2895 	struct ath11k *ar = arvif->ar;
2896 
2897 	lockdep_assert_held(&ar->conf_mutex);
2898 
2899 	if (arvif->vdev_type == WMI_VDEV_TYPE_STA && !sta->tdls)
2900 		return 0;
2901 
2902 	if (ar->num_stations >= ar->max_num_stations)
2903 		return -ENOBUFS;
2904 
2905 	ar->num_stations++;
2906 
2907 	return 0;
2908 }
2909 
2910 static void ath11k_mac_dec_num_stations(struct ath11k_vif *arvif,
2911 					struct ieee80211_sta *sta)
2912 {
2913 	struct ath11k *ar = arvif->ar;
2914 
2915 	lockdep_assert_held(&ar->conf_mutex);
2916 
2917 	if (arvif->vdev_type == WMI_VDEV_TYPE_STA && !sta->tdls)
2918 		return;
2919 
2920 	ar->num_stations--;
2921 }
2922 
2923 static int ath11k_mac_station_add(struct ath11k *ar,
2924 				  struct ieee80211_vif *vif,
2925 				  struct ieee80211_sta *sta)
2926 {
2927 	struct ath11k_base *ab = ar->ab;
2928 	struct ath11k_vif *arvif = ath11k_vif_to_arvif(vif);
2929 	struct ath11k_sta *arsta = (struct ath11k_sta *)sta->drv_priv;
2930 	struct peer_create_params peer_param;
2931 	int ret;
2932 
2933 	lockdep_assert_held(&ar->conf_mutex);
2934 
2935 	ret = ath11k_mac_inc_num_stations(arvif, sta);
2936 	if (ret) {
2937 		ath11k_warn(ab, "refusing to associate station: too many connected already (%d)\n",
2938 			    ar->max_num_stations);
2939 		goto exit;
2940 	}
2941 
2942 	arsta->rx_stats = kzalloc(sizeof(*arsta->rx_stats), GFP_KERNEL);
2943 	if (!arsta->rx_stats) {
2944 		ret = -ENOMEM;
2945 		goto dec_num_station;
2946 	}
2947 
2948 	peer_param.vdev_id = arvif->vdev_id;
2949 	peer_param.peer_addr = sta->addr;
2950 	peer_param.peer_type = WMI_PEER_TYPE_DEFAULT;
2951 
2952 	ret = ath11k_peer_create(ar, arvif, sta, &peer_param);
2953 	if (ret) {
2954 		ath11k_warn(ab, "Failed to add peer: %pM for VDEV: %d\n",
2955 			    sta->addr, arvif->vdev_id);
2956 		goto free_rx_stats;
2957 	}
2958 
2959 	ath11k_dbg(ab, ATH11K_DBG_MAC, "Added peer: %pM for VDEV: %d\n",
2960 		   sta->addr, arvif->vdev_id);
2961 
2962 	if (ath11k_debugfs_is_extd_tx_stats_enabled(ar)) {
2963 		arsta->tx_stats = kzalloc(sizeof(*arsta->tx_stats), GFP_KERNEL);
2964 		if (!arsta->tx_stats) {
2965 			ret = -ENOMEM;
2966 			goto free_peer;
2967 		}
2968 	}
2969 
2970 	if (ieee80211_vif_is_mesh(vif)) {
2971 		ret = ath11k_wmi_set_peer_param(ar, sta->addr,
2972 						arvif->vdev_id,
2973 						WMI_PEER_USE_4ADDR, 1);
2974 		if (ret) {
2975 			ath11k_warn(ab, "failed to STA %pM 4addr capability: %d\n",
2976 				    sta->addr, ret);
2977 			goto free_tx_stats;
2978 		}
2979 	}
2980 
2981 	ret = ath11k_dp_peer_setup(ar, arvif->vdev_id, sta->addr);
2982 	if (ret) {
2983 		ath11k_warn(ab, "failed to setup dp for peer %pM on vdev %i (%d)\n",
2984 			    sta->addr, arvif->vdev_id, ret);
2985 		goto free_tx_stats;
2986 	}
2987 
2988 	if (ab->hw_params.vdev_start_delay &&
2989 	    arvif->vdev_type != WMI_VDEV_TYPE_AP) {
2990 		ret = ath11k_start_vdev_delay(ar->hw, vif);
2991 		if (ret) {
2992 			ath11k_warn(ab, "failed to delay vdev start: %d\n", ret);
2993 			goto free_tx_stats;
2994 		}
2995 	}
2996 
2997 	return 0;
2998 
2999 free_tx_stats:
3000 	kfree(arsta->tx_stats);
3001 	arsta->tx_stats = NULL;
3002 free_peer:
3003 	ath11k_peer_delete(ar, arvif->vdev_id, sta->addr);
3004 free_rx_stats:
3005 	kfree(arsta->rx_stats);
3006 	arsta->rx_stats = NULL;
3007 dec_num_station:
3008 	ath11k_mac_dec_num_stations(arvif, sta);
3009 exit:
3010 	return ret;
3011 }
3012 
3013 static int ath11k_mac_op_sta_state(struct ieee80211_hw *hw,
3014 				   struct ieee80211_vif *vif,
3015 				   struct ieee80211_sta *sta,
3016 				   enum ieee80211_sta_state old_state,
3017 				   enum ieee80211_sta_state new_state)
3018 {
3019 	struct ath11k *ar = hw->priv;
3020 	struct ath11k_vif *arvif = ath11k_vif_to_arvif(vif);
3021 	struct ath11k_sta *arsta = (struct ath11k_sta *)sta->drv_priv;
3022 	struct ath11k_peer *peer;
3023 	int ret = 0;
3024 
3025 	/* cancel must be done outside the mutex to avoid deadlock */
3026 	if ((old_state == IEEE80211_STA_NONE &&
3027 	     new_state == IEEE80211_STA_NOTEXIST))
3028 		cancel_work_sync(&arsta->update_wk);
3029 
3030 	mutex_lock(&ar->conf_mutex);
3031 
3032 	if (old_state == IEEE80211_STA_NOTEXIST &&
3033 	    new_state == IEEE80211_STA_NONE) {
3034 		memset(arsta, 0, sizeof(*arsta));
3035 		arsta->arvif = arvif;
3036 		INIT_WORK(&arsta->update_wk, ath11k_sta_rc_update_wk);
3037 
3038 		ret = ath11k_mac_station_add(ar, vif, sta);
3039 		if (ret)
3040 			ath11k_warn(ar->ab, "Failed to add station: %pM for VDEV: %d\n",
3041 				    sta->addr, arvif->vdev_id);
3042 	} else if ((old_state == IEEE80211_STA_NONE &&
3043 		    new_state == IEEE80211_STA_NOTEXIST)) {
3044 		ath11k_dp_peer_cleanup(ar, arvif->vdev_id, sta->addr);
3045 
3046 		ret = ath11k_peer_delete(ar, arvif->vdev_id, sta->addr);
3047 		if (ret)
3048 			ath11k_warn(ar->ab, "Failed to delete peer: %pM for VDEV: %d\n",
3049 				    sta->addr, arvif->vdev_id);
3050 		else
3051 			ath11k_dbg(ar->ab, ATH11K_DBG_MAC, "Removed peer: %pM for VDEV: %d\n",
3052 				   sta->addr, arvif->vdev_id);
3053 
3054 		ath11k_mac_dec_num_stations(arvif, sta);
3055 		spin_lock_bh(&ar->ab->base_lock);
3056 		peer = ath11k_peer_find(ar->ab, arvif->vdev_id, sta->addr);
3057 		if (peer && peer->sta == sta) {
3058 			ath11k_warn(ar->ab, "Found peer entry %pM n vdev %i after it was supposedly removed\n",
3059 				    vif->addr, arvif->vdev_id);
3060 			peer->sta = NULL;
3061 			list_del(&peer->list);
3062 			kfree(peer);
3063 			ar->num_peers--;
3064 		}
3065 		spin_unlock_bh(&ar->ab->base_lock);
3066 
3067 		kfree(arsta->tx_stats);
3068 		arsta->tx_stats = NULL;
3069 
3070 		kfree(arsta->rx_stats);
3071 		arsta->rx_stats = NULL;
3072 	} else if (old_state == IEEE80211_STA_AUTH &&
3073 		   new_state == IEEE80211_STA_ASSOC &&
3074 		   (vif->type == NL80211_IFTYPE_AP ||
3075 		    vif->type == NL80211_IFTYPE_MESH_POINT ||
3076 		    vif->type == NL80211_IFTYPE_ADHOC)) {
3077 		ret = ath11k_station_assoc(ar, vif, sta, false);
3078 		if (ret)
3079 			ath11k_warn(ar->ab, "Failed to associate station: %pM\n",
3080 				    sta->addr);
3081 	} else if (old_state == IEEE80211_STA_ASSOC &&
3082 		   new_state == IEEE80211_STA_AUTH &&
3083 		   (vif->type == NL80211_IFTYPE_AP ||
3084 		    vif->type == NL80211_IFTYPE_MESH_POINT ||
3085 		    vif->type == NL80211_IFTYPE_ADHOC)) {
3086 		ret = ath11k_station_disassoc(ar, vif, sta);
3087 		if (ret)
3088 			ath11k_warn(ar->ab, "Failed to disassociate station: %pM\n",
3089 				    sta->addr);
3090 	}
3091 
3092 	mutex_unlock(&ar->conf_mutex);
3093 	return ret;
3094 }
3095 
3096 static int ath11k_mac_op_sta_set_txpwr(struct ieee80211_hw *hw,
3097 				       struct ieee80211_vif *vif,
3098 				       struct ieee80211_sta *sta)
3099 {
3100 	struct ath11k *ar = hw->priv;
3101 	struct ath11k_vif *arvif = (void *)vif->drv_priv;
3102 	int ret = 0;
3103 	s16 txpwr;
3104 
3105 	if (sta->txpwr.type == NL80211_TX_POWER_AUTOMATIC) {
3106 		txpwr = 0;
3107 	} else {
3108 		txpwr = sta->txpwr.power;
3109 		if (!txpwr)
3110 			return -EINVAL;
3111 	}
3112 
3113 	if (txpwr > ATH11K_TX_POWER_MAX_VAL || txpwr < ATH11K_TX_POWER_MIN_VAL)
3114 		return -EINVAL;
3115 
3116 	mutex_lock(&ar->conf_mutex);
3117 
3118 	ret = ath11k_wmi_set_peer_param(ar, sta->addr, arvif->vdev_id,
3119 					WMI_PEER_USE_FIXED_PWR, txpwr);
3120 	if (ret) {
3121 		ath11k_warn(ar->ab, "failed to set tx power for station ret: %d\n",
3122 			    ret);
3123 		goto out;
3124 	}
3125 
3126 out:
3127 	mutex_unlock(&ar->conf_mutex);
3128 	return ret;
3129 }
3130 
3131 static void ath11k_mac_op_sta_rc_update(struct ieee80211_hw *hw,
3132 					struct ieee80211_vif *vif,
3133 					struct ieee80211_sta *sta,
3134 					u32 changed)
3135 {
3136 	struct ath11k *ar = hw->priv;
3137 	struct ath11k_sta *arsta = (struct ath11k_sta *)sta->drv_priv;
3138 	struct ath11k_vif *arvif = (void *)vif->drv_priv;
3139 	struct ath11k_peer *peer;
3140 	u32 bw, smps;
3141 
3142 	spin_lock_bh(&ar->ab->base_lock);
3143 
3144 	peer = ath11k_peer_find(ar->ab, arvif->vdev_id, sta->addr);
3145 	if (!peer) {
3146 		spin_unlock_bh(&ar->ab->base_lock);
3147 		ath11k_warn(ar->ab, "mac sta rc update failed to find peer %pM on vdev %i\n",
3148 			    sta->addr, arvif->vdev_id);
3149 		return;
3150 	}
3151 
3152 	spin_unlock_bh(&ar->ab->base_lock);
3153 
3154 	ath11k_dbg(ar->ab, ATH11K_DBG_MAC,
3155 		   "mac sta rc update for %pM changed %08x bw %d nss %d smps %d\n",
3156 		   sta->addr, changed, sta->bandwidth, sta->rx_nss,
3157 		   sta->smps_mode);
3158 
3159 	spin_lock_bh(&ar->data_lock);
3160 
3161 	if (changed & IEEE80211_RC_BW_CHANGED) {
3162 		bw = WMI_PEER_CHWIDTH_20MHZ;
3163 
3164 		switch (sta->bandwidth) {
3165 		case IEEE80211_STA_RX_BW_20:
3166 			bw = WMI_PEER_CHWIDTH_20MHZ;
3167 			break;
3168 		case IEEE80211_STA_RX_BW_40:
3169 			bw = WMI_PEER_CHWIDTH_40MHZ;
3170 			break;
3171 		case IEEE80211_STA_RX_BW_80:
3172 			bw = WMI_PEER_CHWIDTH_80MHZ;
3173 			break;
3174 		case IEEE80211_STA_RX_BW_160:
3175 			bw = WMI_PEER_CHWIDTH_160MHZ;
3176 			break;
3177 		default:
3178 			ath11k_warn(ar->ab, "Invalid bandwidth %d in rc update for %pM\n",
3179 				    sta->bandwidth, sta->addr);
3180 			bw = WMI_PEER_CHWIDTH_20MHZ;
3181 			break;
3182 		}
3183 
3184 		arsta->bw = bw;
3185 	}
3186 
3187 	if (changed & IEEE80211_RC_NSS_CHANGED)
3188 		arsta->nss = sta->rx_nss;
3189 
3190 	if (changed & IEEE80211_RC_SMPS_CHANGED) {
3191 		smps = WMI_PEER_SMPS_PS_NONE;
3192 
3193 		switch (sta->smps_mode) {
3194 		case IEEE80211_SMPS_AUTOMATIC:
3195 		case IEEE80211_SMPS_OFF:
3196 			smps = WMI_PEER_SMPS_PS_NONE;
3197 			break;
3198 		case IEEE80211_SMPS_STATIC:
3199 			smps = WMI_PEER_SMPS_STATIC;
3200 			break;
3201 		case IEEE80211_SMPS_DYNAMIC:
3202 			smps = WMI_PEER_SMPS_DYNAMIC;
3203 			break;
3204 		default:
3205 			ath11k_warn(ar->ab, "Invalid smps %d in sta rc update for %pM\n",
3206 				    sta->smps_mode, sta->addr);
3207 			smps = WMI_PEER_SMPS_PS_NONE;
3208 			break;
3209 		}
3210 
3211 		arsta->smps = smps;
3212 	}
3213 
3214 	arsta->changed |= changed;
3215 
3216 	spin_unlock_bh(&ar->data_lock);
3217 
3218 	ieee80211_queue_work(hw, &arsta->update_wk);
3219 }
3220 
3221 static int ath11k_conf_tx_uapsd(struct ath11k *ar, struct ieee80211_vif *vif,
3222 				u16 ac, bool enable)
3223 {
3224 	struct ath11k_vif *arvif = ath11k_vif_to_arvif(vif);
3225 	u32 value = 0;
3226 	int ret = 0;
3227 
3228 	if (arvif->vdev_type != WMI_VDEV_TYPE_STA)
3229 		return 0;
3230 
3231 	switch (ac) {
3232 	case IEEE80211_AC_VO:
3233 		value = WMI_STA_PS_UAPSD_AC3_DELIVERY_EN |
3234 			WMI_STA_PS_UAPSD_AC3_TRIGGER_EN;
3235 		break;
3236 	case IEEE80211_AC_VI:
3237 		value = WMI_STA_PS_UAPSD_AC2_DELIVERY_EN |
3238 			WMI_STA_PS_UAPSD_AC2_TRIGGER_EN;
3239 		break;
3240 	case IEEE80211_AC_BE:
3241 		value = WMI_STA_PS_UAPSD_AC1_DELIVERY_EN |
3242 			WMI_STA_PS_UAPSD_AC1_TRIGGER_EN;
3243 		break;
3244 	case IEEE80211_AC_BK:
3245 		value = WMI_STA_PS_UAPSD_AC0_DELIVERY_EN |
3246 			WMI_STA_PS_UAPSD_AC0_TRIGGER_EN;
3247 		break;
3248 	}
3249 
3250 	if (enable)
3251 		arvif->u.sta.uapsd |= value;
3252 	else
3253 		arvif->u.sta.uapsd &= ~value;
3254 
3255 	ret = ath11k_wmi_set_sta_ps_param(ar, arvif->vdev_id,
3256 					  WMI_STA_PS_PARAM_UAPSD,
3257 					  arvif->u.sta.uapsd);
3258 	if (ret) {
3259 		ath11k_warn(ar->ab, "could not set uapsd params %d\n", ret);
3260 		goto exit;
3261 	}
3262 
3263 	if (arvif->u.sta.uapsd)
3264 		value = WMI_STA_PS_RX_WAKE_POLICY_POLL_UAPSD;
3265 	else
3266 		value = WMI_STA_PS_RX_WAKE_POLICY_WAKE;
3267 
3268 	ret = ath11k_wmi_set_sta_ps_param(ar, arvif->vdev_id,
3269 					  WMI_STA_PS_PARAM_RX_WAKE_POLICY,
3270 					  value);
3271 	if (ret)
3272 		ath11k_warn(ar->ab, "could not set rx wake param %d\n", ret);
3273 
3274 exit:
3275 	return ret;
3276 }
3277 
3278 static int ath11k_mac_op_conf_tx(struct ieee80211_hw *hw,
3279 				 struct ieee80211_vif *vif, u16 ac,
3280 				 const struct ieee80211_tx_queue_params *params)
3281 {
3282 	struct ath11k *ar = hw->priv;
3283 	struct ath11k_vif *arvif = (void *)vif->drv_priv;
3284 	struct wmi_wmm_params_arg *p = NULL;
3285 	int ret;
3286 
3287 	mutex_lock(&ar->conf_mutex);
3288 
3289 	switch (ac) {
3290 	case IEEE80211_AC_VO:
3291 		p = &arvif->wmm_params.ac_vo;
3292 		break;
3293 	case IEEE80211_AC_VI:
3294 		p = &arvif->wmm_params.ac_vi;
3295 		break;
3296 	case IEEE80211_AC_BE:
3297 		p = &arvif->wmm_params.ac_be;
3298 		break;
3299 	case IEEE80211_AC_BK:
3300 		p = &arvif->wmm_params.ac_bk;
3301 		break;
3302 	}
3303 
3304 	if (WARN_ON(!p)) {
3305 		ret = -EINVAL;
3306 		goto exit;
3307 	}
3308 
3309 	p->cwmin = params->cw_min;
3310 	p->cwmax = params->cw_max;
3311 	p->aifs = params->aifs;
3312 	p->txop = params->txop;
3313 
3314 	ret = ath11k_wmi_send_wmm_update_cmd_tlv(ar, arvif->vdev_id,
3315 						 &arvif->wmm_params);
3316 	if (ret) {
3317 		ath11k_warn(ar->ab, "failed to set wmm params: %d\n", ret);
3318 		goto exit;
3319 	}
3320 
3321 	ret = ath11k_conf_tx_uapsd(ar, vif, ac, params->uapsd);
3322 
3323 	if (ret)
3324 		ath11k_warn(ar->ab, "failed to set sta uapsd: %d\n", ret);
3325 
3326 exit:
3327 	mutex_unlock(&ar->conf_mutex);
3328 	return ret;
3329 }
3330 
3331 static struct ieee80211_sta_ht_cap
3332 ath11k_create_ht_cap(struct ath11k *ar, u32 ar_ht_cap, u32 rate_cap_rx_chainmask)
3333 {
3334 	int i;
3335 	struct ieee80211_sta_ht_cap ht_cap = {0};
3336 	u32 ar_vht_cap = ar->pdev->cap.vht_cap;
3337 
3338 	if (!(ar_ht_cap & WMI_HT_CAP_ENABLED))
3339 		return ht_cap;
3340 
3341 	ht_cap.ht_supported = 1;
3342 	ht_cap.ampdu_factor = IEEE80211_HT_MAX_AMPDU_64K;
3343 	ht_cap.ampdu_density = IEEE80211_HT_MPDU_DENSITY_NONE;
3344 	ht_cap.cap |= IEEE80211_HT_CAP_SUP_WIDTH_20_40;
3345 	ht_cap.cap |= IEEE80211_HT_CAP_DSSSCCK40;
3346 	ht_cap.cap |= WLAN_HT_CAP_SM_PS_STATIC << IEEE80211_HT_CAP_SM_PS_SHIFT;
3347 
3348 	if (ar_ht_cap & WMI_HT_CAP_HT20_SGI)
3349 		ht_cap.cap |= IEEE80211_HT_CAP_SGI_20;
3350 
3351 	if (ar_ht_cap & WMI_HT_CAP_HT40_SGI)
3352 		ht_cap.cap |= IEEE80211_HT_CAP_SGI_40;
3353 
3354 	if (ar_ht_cap & WMI_HT_CAP_DYNAMIC_SMPS) {
3355 		u32 smps;
3356 
3357 		smps   = WLAN_HT_CAP_SM_PS_DYNAMIC;
3358 		smps <<= IEEE80211_HT_CAP_SM_PS_SHIFT;
3359 
3360 		ht_cap.cap |= smps;
3361 	}
3362 
3363 	if (ar_ht_cap & WMI_HT_CAP_TX_STBC)
3364 		ht_cap.cap |= IEEE80211_HT_CAP_TX_STBC;
3365 
3366 	if (ar_ht_cap & WMI_HT_CAP_RX_STBC) {
3367 		u32 stbc;
3368 
3369 		stbc   = ar_ht_cap;
3370 		stbc  &= WMI_HT_CAP_RX_STBC;
3371 		stbc >>= WMI_HT_CAP_RX_STBC_MASK_SHIFT;
3372 		stbc <<= IEEE80211_HT_CAP_RX_STBC_SHIFT;
3373 		stbc  &= IEEE80211_HT_CAP_RX_STBC;
3374 
3375 		ht_cap.cap |= stbc;
3376 	}
3377 
3378 	if (ar_ht_cap & WMI_HT_CAP_RX_LDPC)
3379 		ht_cap.cap |= IEEE80211_HT_CAP_LDPC_CODING;
3380 
3381 	if (ar_ht_cap & WMI_HT_CAP_L_SIG_TXOP_PROT)
3382 		ht_cap.cap |= IEEE80211_HT_CAP_LSIG_TXOP_PROT;
3383 
3384 	if (ar_vht_cap & WMI_VHT_CAP_MAX_MPDU_LEN_MASK)
3385 		ht_cap.cap |= IEEE80211_HT_CAP_MAX_AMSDU;
3386 
3387 	for (i = 0; i < ar->num_rx_chains; i++) {
3388 		if (rate_cap_rx_chainmask & BIT(i))
3389 			ht_cap.mcs.rx_mask[i] = 0xFF;
3390 	}
3391 
3392 	ht_cap.mcs.tx_params |= IEEE80211_HT_MCS_TX_DEFINED;
3393 
3394 	return ht_cap;
3395 }
3396 
3397 static int ath11k_mac_set_txbf_conf(struct ath11k_vif *arvif)
3398 {
3399 	u32 value = 0;
3400 	struct ath11k *ar = arvif->ar;
3401 	int nsts;
3402 	int sound_dim;
3403 	u32 vht_cap = ar->pdev->cap.vht_cap;
3404 	u32 vdev_param = WMI_VDEV_PARAM_TXBF;
3405 
3406 	if (vht_cap & (IEEE80211_VHT_CAP_SU_BEAMFORMEE_CAPABLE)) {
3407 		nsts = vht_cap & IEEE80211_VHT_CAP_BEAMFORMEE_STS_MASK;
3408 		nsts >>= IEEE80211_VHT_CAP_BEAMFORMEE_STS_SHIFT;
3409 		value |= SM(nsts, WMI_TXBF_STS_CAP_OFFSET);
3410 	}
3411 
3412 	if (vht_cap & (IEEE80211_VHT_CAP_SU_BEAMFORMER_CAPABLE)) {
3413 		sound_dim = vht_cap &
3414 			    IEEE80211_VHT_CAP_SOUNDING_DIMENSIONS_MASK;
3415 		sound_dim >>= IEEE80211_VHT_CAP_SOUNDING_DIMENSIONS_SHIFT;
3416 		if (sound_dim > (ar->num_tx_chains - 1))
3417 			sound_dim = ar->num_tx_chains - 1;
3418 		value |= SM(sound_dim, WMI_BF_SOUND_DIM_OFFSET);
3419 	}
3420 
3421 	if (!value)
3422 		return 0;
3423 
3424 	if (vht_cap & IEEE80211_VHT_CAP_SU_BEAMFORMER_CAPABLE) {
3425 		value |= WMI_VDEV_PARAM_TXBF_SU_TX_BFER;
3426 
3427 		if ((vht_cap & IEEE80211_VHT_CAP_MU_BEAMFORMER_CAPABLE) &&
3428 		    arvif->vdev_type == WMI_VDEV_TYPE_AP)
3429 			value |= WMI_VDEV_PARAM_TXBF_MU_TX_BFER;
3430 	}
3431 
3432 	/* TODO: SUBFEE not validated in HK, disable here until validated? */
3433 
3434 	if (vht_cap & IEEE80211_VHT_CAP_SU_BEAMFORMEE_CAPABLE) {
3435 		value |= WMI_VDEV_PARAM_TXBF_SU_TX_BFEE;
3436 
3437 		if ((vht_cap & IEEE80211_VHT_CAP_MU_BEAMFORMEE_CAPABLE) &&
3438 		    arvif->vdev_type == WMI_VDEV_TYPE_STA)
3439 			value |= WMI_VDEV_PARAM_TXBF_MU_TX_BFEE;
3440 	}
3441 
3442 	return ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
3443 					     vdev_param, value);
3444 }
3445 
3446 static void ath11k_set_vht_txbf_cap(struct ath11k *ar, u32 *vht_cap)
3447 {
3448 	bool subfer, subfee;
3449 	int sound_dim = 0;
3450 
3451 	subfer = !!(*vht_cap & (IEEE80211_VHT_CAP_SU_BEAMFORMER_CAPABLE));
3452 	subfee = !!(*vht_cap & (IEEE80211_VHT_CAP_SU_BEAMFORMEE_CAPABLE));
3453 
3454 	if (ar->num_tx_chains < 2) {
3455 		*vht_cap &= ~(IEEE80211_VHT_CAP_SU_BEAMFORMER_CAPABLE);
3456 		subfer = false;
3457 	}
3458 
3459 	/* If SU Beaformer is not set, then disable MU Beamformer Capability */
3460 	if (!subfer)
3461 		*vht_cap &= ~(IEEE80211_VHT_CAP_MU_BEAMFORMER_CAPABLE);
3462 
3463 	/* If SU Beaformee is not set, then disable MU Beamformee Capability */
3464 	if (!subfee)
3465 		*vht_cap &= ~(IEEE80211_VHT_CAP_MU_BEAMFORMEE_CAPABLE);
3466 
3467 	sound_dim = (*vht_cap & IEEE80211_VHT_CAP_SOUNDING_DIMENSIONS_MASK);
3468 	sound_dim >>= IEEE80211_VHT_CAP_SOUNDING_DIMENSIONS_SHIFT;
3469 	*vht_cap &= ~IEEE80211_VHT_CAP_SOUNDING_DIMENSIONS_MASK;
3470 
3471 	/* TODO: Need to check invalid STS and Sound_dim values set by FW? */
3472 
3473 	/* Enable Sounding Dimension Field only if SU BF is enabled */
3474 	if (subfer) {
3475 		if (sound_dim > (ar->num_tx_chains - 1))
3476 			sound_dim = ar->num_tx_chains - 1;
3477 
3478 		sound_dim <<= IEEE80211_VHT_CAP_SOUNDING_DIMENSIONS_SHIFT;
3479 		sound_dim &=  IEEE80211_VHT_CAP_SOUNDING_DIMENSIONS_MASK;
3480 		*vht_cap |= sound_dim;
3481 	}
3482 
3483 	/* Use the STS advertised by FW unless SU Beamformee is not supported*/
3484 	if (!subfee)
3485 		*vht_cap &= ~(IEEE80211_VHT_CAP_BEAMFORMEE_STS_MASK);
3486 }
3487 
3488 static struct ieee80211_sta_vht_cap
3489 ath11k_create_vht_cap(struct ath11k *ar, u32 rate_cap_tx_chainmask,
3490 		      u32 rate_cap_rx_chainmask)
3491 {
3492 	struct ieee80211_sta_vht_cap vht_cap = {0};
3493 	u16 txmcs_map, rxmcs_map;
3494 	int i;
3495 
3496 	vht_cap.vht_supported = 1;
3497 	vht_cap.cap = ar->pdev->cap.vht_cap;
3498 
3499 	ath11k_set_vht_txbf_cap(ar, &vht_cap.cap);
3500 
3501 	/* TODO: Enable back VHT160 mode once association issues are fixed */
3502 	/* Disabling VHT160 and VHT80+80 modes */
3503 	vht_cap.cap &= ~IEEE80211_VHT_CAP_SUPP_CHAN_WIDTH_MASK;
3504 	vht_cap.cap &= ~IEEE80211_VHT_CAP_SHORT_GI_160;
3505 
3506 	rxmcs_map = 0;
3507 	txmcs_map = 0;
3508 	for (i = 0; i < 8; i++) {
3509 		if (i < ar->num_tx_chains && rate_cap_tx_chainmask & BIT(i))
3510 			txmcs_map |= IEEE80211_VHT_MCS_SUPPORT_0_9 << (i * 2);
3511 		else
3512 			txmcs_map |= IEEE80211_VHT_MCS_NOT_SUPPORTED << (i * 2);
3513 
3514 		if (i < ar->num_rx_chains && rate_cap_rx_chainmask & BIT(i))
3515 			rxmcs_map |= IEEE80211_VHT_MCS_SUPPORT_0_9 << (i * 2);
3516 		else
3517 			rxmcs_map |= IEEE80211_VHT_MCS_NOT_SUPPORTED << (i * 2);
3518 	}
3519 
3520 	if (rate_cap_tx_chainmask <= 1)
3521 		vht_cap.cap &= ~IEEE80211_VHT_CAP_TXSTBC;
3522 
3523 	vht_cap.vht_mcs.rx_mcs_map = cpu_to_le16(rxmcs_map);
3524 	vht_cap.vht_mcs.tx_mcs_map = cpu_to_le16(txmcs_map);
3525 
3526 	return vht_cap;
3527 }
3528 
3529 static void ath11k_mac_setup_ht_vht_cap(struct ath11k *ar,
3530 					struct ath11k_pdev_cap *cap,
3531 					u32 *ht_cap_info)
3532 {
3533 	struct ieee80211_supported_band *band;
3534 	u32 rate_cap_tx_chainmask;
3535 	u32 rate_cap_rx_chainmask;
3536 	u32 ht_cap;
3537 
3538 	rate_cap_tx_chainmask = ar->cfg_tx_chainmask >> cap->tx_chain_mask_shift;
3539 	rate_cap_rx_chainmask = ar->cfg_rx_chainmask >> cap->rx_chain_mask_shift;
3540 
3541 	if (cap->supported_bands & WMI_HOST_WLAN_2G_CAP) {
3542 		band = &ar->mac.sbands[NL80211_BAND_2GHZ];
3543 		ht_cap = cap->band[NL80211_BAND_2GHZ].ht_cap_info;
3544 		if (ht_cap_info)
3545 			*ht_cap_info = ht_cap;
3546 		band->ht_cap = ath11k_create_ht_cap(ar, ht_cap,
3547 						    rate_cap_rx_chainmask);
3548 	}
3549 
3550 	if (cap->supported_bands & WMI_HOST_WLAN_5G_CAP && !ar->supports_6ghz) {
3551 		band = &ar->mac.sbands[NL80211_BAND_5GHZ];
3552 		ht_cap = cap->band[NL80211_BAND_5GHZ].ht_cap_info;
3553 		if (ht_cap_info)
3554 			*ht_cap_info = ht_cap;
3555 		band->ht_cap = ath11k_create_ht_cap(ar, ht_cap,
3556 						    rate_cap_rx_chainmask);
3557 		band->vht_cap = ath11k_create_vht_cap(ar, rate_cap_tx_chainmask,
3558 						      rate_cap_rx_chainmask);
3559 	}
3560 }
3561 
3562 static int ath11k_check_chain_mask(struct ath11k *ar, u32 ant, bool is_tx_ant)
3563 {
3564 	/* TODO: Check the request chainmask against the supported
3565 	 * chainmask table which is advertised in extented_service_ready event
3566 	 */
3567 
3568 	return 0;
3569 }
3570 
3571 static void ath11k_gen_ppe_thresh(struct ath11k_ppe_threshold *fw_ppet,
3572 				  u8 *he_ppet)
3573 {
3574 	int nss, ru;
3575 	u8 bit = 7;
3576 
3577 	he_ppet[0] = fw_ppet->numss_m1 & IEEE80211_PPE_THRES_NSS_MASK;
3578 	he_ppet[0] |= (fw_ppet->ru_bit_mask <<
3579 		       IEEE80211_PPE_THRES_RU_INDEX_BITMASK_POS) &
3580 		      IEEE80211_PPE_THRES_RU_INDEX_BITMASK_MASK;
3581 	for (nss = 0; nss <= fw_ppet->numss_m1; nss++) {
3582 		for (ru = 0; ru < 4; ru++) {
3583 			u8 val;
3584 			int i;
3585 
3586 			if ((fw_ppet->ru_bit_mask & BIT(ru)) == 0)
3587 				continue;
3588 			val = (fw_ppet->ppet16_ppet8_ru3_ru0[nss] >> (ru * 6)) &
3589 			       0x3f;
3590 			val = ((val >> 3) & 0x7) | ((val & 0x7) << 3);
3591 			for (i = 5; i >= 0; i--) {
3592 				he_ppet[bit / 8] |=
3593 					((val >> i) & 0x1) << ((bit % 8));
3594 				bit++;
3595 			}
3596 		}
3597 	}
3598 }
3599 
3600 static void
3601 ath11k_mac_filter_he_cap_mesh(struct ieee80211_he_cap_elem *he_cap_elem)
3602 {
3603 	u8 m;
3604 
3605 	m = IEEE80211_HE_MAC_CAP0_TWT_RES |
3606 	    IEEE80211_HE_MAC_CAP0_TWT_REQ;
3607 	he_cap_elem->mac_cap_info[0] &= ~m;
3608 
3609 	m = IEEE80211_HE_MAC_CAP2_TRS |
3610 	    IEEE80211_HE_MAC_CAP2_BCAST_TWT |
3611 	    IEEE80211_HE_MAC_CAP2_MU_CASCADING;
3612 	he_cap_elem->mac_cap_info[2] &= ~m;
3613 
3614 	m = IEEE80211_HE_MAC_CAP3_FLEX_TWT_SCHED |
3615 	    IEEE80211_HE_MAC_CAP2_BCAST_TWT |
3616 	    IEEE80211_HE_MAC_CAP2_MU_CASCADING;
3617 	he_cap_elem->mac_cap_info[3] &= ~m;
3618 
3619 	m = IEEE80211_HE_MAC_CAP4_BSRP_BQRP_A_MPDU_AGG |
3620 	    IEEE80211_HE_MAC_CAP4_BQR;
3621 	he_cap_elem->mac_cap_info[4] &= ~m;
3622 
3623 	m = IEEE80211_HE_MAC_CAP5_SUBCHAN_SELECVITE_TRANSMISSION |
3624 	    IEEE80211_HE_MAC_CAP5_UL_2x996_TONE_RU |
3625 	    IEEE80211_HE_MAC_CAP5_PUNCTURED_SOUNDING |
3626 	    IEEE80211_HE_MAC_CAP5_HT_VHT_TRIG_FRAME_RX;
3627 	he_cap_elem->mac_cap_info[5] &= ~m;
3628 
3629 	m = IEEE80211_HE_PHY_CAP2_UL_MU_FULL_MU_MIMO |
3630 	    IEEE80211_HE_PHY_CAP2_UL_MU_PARTIAL_MU_MIMO;
3631 	he_cap_elem->phy_cap_info[2] &= ~m;
3632 
3633 	m = IEEE80211_HE_PHY_CAP3_RX_HE_MU_PPDU_FROM_NON_AP_STA |
3634 	    IEEE80211_HE_PHY_CAP3_DCM_MAX_CONST_TX_MASK |
3635 	    IEEE80211_HE_PHY_CAP3_DCM_MAX_CONST_RX_MASK;
3636 	he_cap_elem->phy_cap_info[3] &= ~m;
3637 
3638 	m = IEEE80211_HE_PHY_CAP4_MU_BEAMFORMER;
3639 	he_cap_elem->phy_cap_info[4] &= ~m;
3640 
3641 	m = IEEE80211_HE_PHY_CAP5_NG16_MU_FEEDBACK;
3642 	he_cap_elem->phy_cap_info[5] &= ~m;
3643 
3644 	m = IEEE80211_HE_PHY_CAP6_CODEBOOK_SIZE_75_MU |
3645 	    IEEE80211_HE_PHY_CAP6_TRIG_MU_BEAMFORMER_FB |
3646 	    IEEE80211_HE_PHY_CAP6_TRIG_CQI_FB |
3647 	    IEEE80211_HE_PHY_CAP6_PARTIAL_BANDWIDTH_DL_MUMIMO;
3648 	he_cap_elem->phy_cap_info[6] &= ~m;
3649 
3650 	m = IEEE80211_HE_PHY_CAP7_SRP_BASED_SR |
3651 	    IEEE80211_HE_PHY_CAP7_POWER_BOOST_FACTOR_AR |
3652 	    IEEE80211_HE_PHY_CAP7_STBC_TX_ABOVE_80MHZ |
3653 	    IEEE80211_HE_PHY_CAP7_STBC_RX_ABOVE_80MHZ;
3654 	he_cap_elem->phy_cap_info[7] &= ~m;
3655 
3656 	m = IEEE80211_HE_PHY_CAP8_HE_ER_SU_PPDU_4XLTF_AND_08_US_GI |
3657 	    IEEE80211_HE_PHY_CAP8_20MHZ_IN_40MHZ_HE_PPDU_IN_2G |
3658 	    IEEE80211_HE_PHY_CAP8_20MHZ_IN_160MHZ_HE_PPDU |
3659 	    IEEE80211_HE_PHY_CAP8_80MHZ_IN_160MHZ_HE_PPDU;
3660 	he_cap_elem->phy_cap_info[8] &= ~m;
3661 
3662 	m = IEEE80211_HE_PHY_CAP9_LONGER_THAN_16_SIGB_OFDM_SYM |
3663 	    IEEE80211_HE_PHY_CAP9_NON_TRIGGERED_CQI_FEEDBACK |
3664 	    IEEE80211_HE_PHY_CAP9_RX_1024_QAM_LESS_THAN_242_TONE_RU |
3665 	    IEEE80211_HE_PHY_CAP9_TX_1024_QAM_LESS_THAN_242_TONE_RU |
3666 	    IEEE80211_HE_PHY_CAP9_RX_FULL_BW_SU_USING_MU_WITH_COMP_SIGB |
3667 	    IEEE80211_HE_PHY_CAP9_RX_FULL_BW_SU_USING_MU_WITH_NON_COMP_SIGB;
3668 	he_cap_elem->phy_cap_info[9] &= ~m;
3669 }
3670 
3671 static __le16 ath11k_mac_setup_he_6ghz_cap(struct ath11k_pdev_cap *pcap,
3672 					   struct ath11k_band_cap *bcap)
3673 {
3674 	u8 val;
3675 
3676 	bcap->he_6ghz_capa = IEEE80211_HT_MPDU_DENSITY_NONE;
3677 	if (bcap->ht_cap_info & WMI_HT_CAP_DYNAMIC_SMPS)
3678 		bcap->he_6ghz_capa |=
3679 			FIELD_PREP(IEEE80211_HE_6GHZ_CAP_SM_PS,
3680 				   WLAN_HT_CAP_SM_PS_DYNAMIC);
3681 	else
3682 		bcap->he_6ghz_capa |=
3683 			FIELD_PREP(IEEE80211_HE_6GHZ_CAP_SM_PS,
3684 				   WLAN_HT_CAP_SM_PS_DISABLED);
3685 	val = FIELD_GET(IEEE80211_VHT_CAP_MAX_A_MPDU_LENGTH_EXPONENT_MASK,
3686 			pcap->vht_cap);
3687 	bcap->he_6ghz_capa |=
3688 		FIELD_PREP(IEEE80211_HE_6GHZ_CAP_MAX_AMPDU_LEN_EXP, val);
3689 	val = FIELD_GET(IEEE80211_VHT_CAP_MAX_MPDU_MASK, pcap->vht_cap);
3690 	bcap->he_6ghz_capa |=
3691 		FIELD_PREP(IEEE80211_HE_6GHZ_CAP_MAX_MPDU_LEN, val);
3692 	if (pcap->vht_cap & IEEE80211_VHT_CAP_RX_ANTENNA_PATTERN)
3693 		bcap->he_6ghz_capa |= IEEE80211_HE_6GHZ_CAP_RX_ANTPAT_CONS;
3694 	if (pcap->vht_cap & IEEE80211_VHT_CAP_TX_ANTENNA_PATTERN)
3695 		bcap->he_6ghz_capa |= IEEE80211_HE_6GHZ_CAP_TX_ANTPAT_CONS;
3696 
3697 	return cpu_to_le16(bcap->he_6ghz_capa);
3698 }
3699 
3700 static int ath11k_mac_copy_he_cap(struct ath11k *ar,
3701 				  struct ath11k_pdev_cap *cap,
3702 				  struct ieee80211_sband_iftype_data *data,
3703 				  int band)
3704 {
3705 	int i, idx = 0;
3706 
3707 	for (i = 0; i < NUM_NL80211_IFTYPES; i++) {
3708 		struct ieee80211_sta_he_cap *he_cap = &data[idx].he_cap;
3709 		struct ath11k_band_cap *band_cap = &cap->band[band];
3710 		struct ieee80211_he_cap_elem *he_cap_elem =
3711 				&he_cap->he_cap_elem;
3712 
3713 		switch (i) {
3714 		case NL80211_IFTYPE_STATION:
3715 		case NL80211_IFTYPE_AP:
3716 		case NL80211_IFTYPE_MESH_POINT:
3717 			break;
3718 
3719 		default:
3720 			continue;
3721 		}
3722 
3723 		data[idx].types_mask = BIT(i);
3724 		he_cap->has_he = true;
3725 		memcpy(he_cap_elem->mac_cap_info, band_cap->he_cap_info,
3726 		       sizeof(he_cap_elem->mac_cap_info));
3727 		memcpy(he_cap_elem->phy_cap_info, band_cap->he_cap_phy_info,
3728 		       sizeof(he_cap_elem->phy_cap_info));
3729 
3730 		he_cap_elem->mac_cap_info[1] &=
3731 			IEEE80211_HE_MAC_CAP1_TF_MAC_PAD_DUR_MASK;
3732 		he_cap_elem->phy_cap_info[4] &=
3733 			~IEEE80211_HE_PHY_CAP4_BEAMFORMEE_MAX_STS_UNDER_80MHZ_MASK;
3734 		he_cap_elem->phy_cap_info[4] &=
3735 			~IEEE80211_HE_PHY_CAP4_BEAMFORMEE_MAX_STS_ABOVE_80MHZ_MASK;
3736 		he_cap_elem->phy_cap_info[4] |= (ar->num_tx_chains - 1) << 2;
3737 
3738 		he_cap_elem->phy_cap_info[5] &=
3739 			~IEEE80211_HE_PHY_CAP5_BEAMFORMEE_NUM_SND_DIM_UNDER_80MHZ_MASK;
3740 		he_cap_elem->phy_cap_info[5] &=
3741 			~IEEE80211_HE_PHY_CAP5_BEAMFORMEE_NUM_SND_DIM_ABOVE_80MHZ_MASK;
3742 		he_cap_elem->phy_cap_info[5] |= ar->num_tx_chains - 1;
3743 
3744 		switch (i) {
3745 		case NL80211_IFTYPE_AP:
3746 			he_cap_elem->phy_cap_info[3] &=
3747 				~IEEE80211_HE_PHY_CAP3_DCM_MAX_CONST_TX_MASK;
3748 			he_cap_elem->phy_cap_info[9] |=
3749 				IEEE80211_HE_PHY_CAP9_RX_1024_QAM_LESS_THAN_242_TONE_RU;
3750 			break;
3751 		case NL80211_IFTYPE_STATION:
3752 			he_cap_elem->mac_cap_info[0] &=
3753 				~IEEE80211_HE_MAC_CAP0_TWT_RES;
3754 			he_cap_elem->mac_cap_info[0] |=
3755 				IEEE80211_HE_MAC_CAP0_TWT_REQ;
3756 			he_cap_elem->phy_cap_info[9] |=
3757 				IEEE80211_HE_PHY_CAP9_TX_1024_QAM_LESS_THAN_242_TONE_RU;
3758 			break;
3759 		case NL80211_IFTYPE_MESH_POINT:
3760 			ath11k_mac_filter_he_cap_mesh(he_cap_elem);
3761 			break;
3762 		}
3763 
3764 		he_cap->he_mcs_nss_supp.rx_mcs_80 =
3765 			cpu_to_le16(band_cap->he_mcs & 0xffff);
3766 		he_cap->he_mcs_nss_supp.tx_mcs_80 =
3767 			cpu_to_le16(band_cap->he_mcs & 0xffff);
3768 		he_cap->he_mcs_nss_supp.rx_mcs_160 =
3769 			cpu_to_le16((band_cap->he_mcs >> 16) & 0xffff);
3770 		he_cap->he_mcs_nss_supp.tx_mcs_160 =
3771 			cpu_to_le16((band_cap->he_mcs >> 16) & 0xffff);
3772 		he_cap->he_mcs_nss_supp.rx_mcs_80p80 =
3773 			cpu_to_le16((band_cap->he_mcs >> 16) & 0xffff);
3774 		he_cap->he_mcs_nss_supp.tx_mcs_80p80 =
3775 			cpu_to_le16((band_cap->he_mcs >> 16) & 0xffff);
3776 
3777 		memset(he_cap->ppe_thres, 0, sizeof(he_cap->ppe_thres));
3778 		if (he_cap_elem->phy_cap_info[6] &
3779 		    IEEE80211_HE_PHY_CAP6_PPE_THRESHOLD_PRESENT)
3780 			ath11k_gen_ppe_thresh(&band_cap->he_ppet,
3781 					      he_cap->ppe_thres);
3782 
3783 		if (band == NL80211_BAND_6GHZ) {
3784 			data[idx].he_6ghz_capa.capa =
3785 				ath11k_mac_setup_he_6ghz_cap(cap, band_cap);
3786 		}
3787 		idx++;
3788 	}
3789 
3790 	return idx;
3791 }
3792 
3793 static void ath11k_mac_setup_he_cap(struct ath11k *ar,
3794 				    struct ath11k_pdev_cap *cap)
3795 {
3796 	struct ieee80211_supported_band *band;
3797 	int count;
3798 
3799 	if (cap->supported_bands & WMI_HOST_WLAN_2G_CAP) {
3800 		count = ath11k_mac_copy_he_cap(ar, cap,
3801 					       ar->mac.iftype[NL80211_BAND_2GHZ],
3802 					       NL80211_BAND_2GHZ);
3803 		band = &ar->mac.sbands[NL80211_BAND_2GHZ];
3804 		band->iftype_data = ar->mac.iftype[NL80211_BAND_2GHZ];
3805 		band->n_iftype_data = count;
3806 	}
3807 
3808 	if (cap->supported_bands & WMI_HOST_WLAN_5G_CAP) {
3809 		count = ath11k_mac_copy_he_cap(ar, cap,
3810 					       ar->mac.iftype[NL80211_BAND_5GHZ],
3811 					       NL80211_BAND_5GHZ);
3812 		band = &ar->mac.sbands[NL80211_BAND_5GHZ];
3813 		band->iftype_data = ar->mac.iftype[NL80211_BAND_5GHZ];
3814 		band->n_iftype_data = count;
3815 	}
3816 
3817 	if (cap->supported_bands & WMI_HOST_WLAN_5G_CAP &&
3818 	    ar->supports_6ghz) {
3819 		count = ath11k_mac_copy_he_cap(ar, cap,
3820 					       ar->mac.iftype[NL80211_BAND_6GHZ],
3821 					       NL80211_BAND_6GHZ);
3822 		band = &ar->mac.sbands[NL80211_BAND_6GHZ];
3823 		band->iftype_data = ar->mac.iftype[NL80211_BAND_6GHZ];
3824 		band->n_iftype_data = count;
3825 	}
3826 }
3827 
3828 static int __ath11k_set_antenna(struct ath11k *ar, u32 tx_ant, u32 rx_ant)
3829 {
3830 	int ret;
3831 
3832 	lockdep_assert_held(&ar->conf_mutex);
3833 
3834 	if (ath11k_check_chain_mask(ar, tx_ant, true))
3835 		return -EINVAL;
3836 
3837 	if (ath11k_check_chain_mask(ar, rx_ant, false))
3838 		return -EINVAL;
3839 
3840 	ar->cfg_tx_chainmask = tx_ant;
3841 	ar->cfg_rx_chainmask = rx_ant;
3842 
3843 	if (ar->state != ATH11K_STATE_ON &&
3844 	    ar->state != ATH11K_STATE_RESTARTED)
3845 		return 0;
3846 
3847 	ret = ath11k_wmi_pdev_set_param(ar, WMI_PDEV_PARAM_TX_CHAIN_MASK,
3848 					tx_ant, ar->pdev->pdev_id);
3849 	if (ret) {
3850 		ath11k_warn(ar->ab, "failed to set tx-chainmask: %d, req 0x%x\n",
3851 			    ret, tx_ant);
3852 		return ret;
3853 	}
3854 
3855 	ar->num_tx_chains = get_num_chains(tx_ant);
3856 
3857 	ret = ath11k_wmi_pdev_set_param(ar, WMI_PDEV_PARAM_RX_CHAIN_MASK,
3858 					rx_ant, ar->pdev->pdev_id);
3859 	if (ret) {
3860 		ath11k_warn(ar->ab, "failed to set rx-chainmask: %d, req 0x%x\n",
3861 			    ret, rx_ant);
3862 		return ret;
3863 	}
3864 
3865 	ar->num_rx_chains = get_num_chains(rx_ant);
3866 
3867 	/* Reload HT/VHT/HE capability */
3868 	ath11k_mac_setup_ht_vht_cap(ar, &ar->pdev->cap, NULL);
3869 	ath11k_mac_setup_he_cap(ar, &ar->pdev->cap);
3870 
3871 	return 0;
3872 }
3873 
3874 int ath11k_mac_tx_mgmt_pending_free(int buf_id, void *skb, void *ctx)
3875 {
3876 	struct sk_buff *msdu = skb;
3877 	struct ieee80211_tx_info *info;
3878 	struct ath11k *ar = ctx;
3879 	struct ath11k_base *ab = ar->ab;
3880 
3881 	spin_lock_bh(&ar->txmgmt_idr_lock);
3882 	idr_remove(&ar->txmgmt_idr, buf_id);
3883 	spin_unlock_bh(&ar->txmgmt_idr_lock);
3884 	dma_unmap_single(ab->dev, ATH11K_SKB_CB(msdu)->paddr, msdu->len,
3885 			 DMA_TO_DEVICE);
3886 
3887 	info = IEEE80211_SKB_CB(msdu);
3888 	memset(&info->status, 0, sizeof(info->status));
3889 
3890 	ieee80211_free_txskb(ar->hw, msdu);
3891 
3892 	return 0;
3893 }
3894 
3895 static int ath11k_mac_vif_txmgmt_idr_remove(int buf_id, void *skb, void *ctx)
3896 {
3897 	struct ieee80211_vif *vif = ctx;
3898 	struct ath11k_skb_cb *skb_cb = ATH11K_SKB_CB((struct sk_buff *)skb);
3899 	struct sk_buff *msdu = skb;
3900 	struct ath11k *ar = skb_cb->ar;
3901 	struct ath11k_base *ab = ar->ab;
3902 
3903 	if (skb_cb->vif == vif) {
3904 		spin_lock_bh(&ar->txmgmt_idr_lock);
3905 		idr_remove(&ar->txmgmt_idr, buf_id);
3906 		spin_unlock_bh(&ar->txmgmt_idr_lock);
3907 		dma_unmap_single(ab->dev, skb_cb->paddr, msdu->len,
3908 				 DMA_TO_DEVICE);
3909 	}
3910 
3911 	return 0;
3912 }
3913 
3914 static int ath11k_mac_mgmt_tx_wmi(struct ath11k *ar, struct ath11k_vif *arvif,
3915 				  struct sk_buff *skb)
3916 {
3917 	struct ath11k_base *ab = ar->ab;
3918 	struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data;
3919 	struct ieee80211_tx_info *info;
3920 	dma_addr_t paddr;
3921 	int buf_id;
3922 	int ret;
3923 
3924 	spin_lock_bh(&ar->txmgmt_idr_lock);
3925 	buf_id = idr_alloc(&ar->txmgmt_idr, skb, 0,
3926 			   ATH11K_TX_MGMT_NUM_PENDING_MAX, GFP_ATOMIC);
3927 	spin_unlock_bh(&ar->txmgmt_idr_lock);
3928 	if (buf_id < 0)
3929 		return -ENOSPC;
3930 
3931 	info = IEEE80211_SKB_CB(skb);
3932 	if (!(info->flags & IEEE80211_TX_CTL_HW_80211_ENCAP)) {
3933 		if ((ieee80211_is_action(hdr->frame_control) ||
3934 		     ieee80211_is_deauth(hdr->frame_control) ||
3935 		     ieee80211_is_disassoc(hdr->frame_control)) &&
3936 		     ieee80211_has_protected(hdr->frame_control)) {
3937 			skb_put(skb, IEEE80211_CCMP_MIC_LEN);
3938 		}
3939 	}
3940 
3941 	paddr = dma_map_single(ab->dev, skb->data, skb->len, DMA_TO_DEVICE);
3942 	if (dma_mapping_error(ab->dev, paddr)) {
3943 		ath11k_warn(ab, "failed to DMA map mgmt Tx buffer\n");
3944 		ret = -EIO;
3945 		goto err_free_idr;
3946 	}
3947 
3948 	ATH11K_SKB_CB(skb)->paddr = paddr;
3949 
3950 	ret = ath11k_wmi_mgmt_send(ar, arvif->vdev_id, buf_id, skb);
3951 	if (ret) {
3952 		ath11k_warn(ar->ab, "failed to send mgmt frame: %d\n", ret);
3953 		goto err_unmap_buf;
3954 	}
3955 
3956 	return 0;
3957 
3958 err_unmap_buf:
3959 	dma_unmap_single(ab->dev, ATH11K_SKB_CB(skb)->paddr,
3960 			 skb->len, DMA_TO_DEVICE);
3961 err_free_idr:
3962 	spin_lock_bh(&ar->txmgmt_idr_lock);
3963 	idr_remove(&ar->txmgmt_idr, buf_id);
3964 	spin_unlock_bh(&ar->txmgmt_idr_lock);
3965 
3966 	return ret;
3967 }
3968 
3969 static void ath11k_mgmt_over_wmi_tx_purge(struct ath11k *ar)
3970 {
3971 	struct sk_buff *skb;
3972 
3973 	while ((skb = skb_dequeue(&ar->wmi_mgmt_tx_queue)) != NULL)
3974 		ieee80211_free_txskb(ar->hw, skb);
3975 }
3976 
3977 static void ath11k_mgmt_over_wmi_tx_work(struct work_struct *work)
3978 {
3979 	struct ath11k *ar = container_of(work, struct ath11k, wmi_mgmt_tx_work);
3980 	struct ieee80211_tx_info *info;
3981 	struct ath11k_vif *arvif;
3982 	struct sk_buff *skb;
3983 	int ret;
3984 
3985 	while ((skb = skb_dequeue(&ar->wmi_mgmt_tx_queue)) != NULL) {
3986 		info = IEEE80211_SKB_CB(skb);
3987 		if (!info->control.vif) {
3988 			ath11k_warn(ar->ab, "no vif found for mgmt frame, flags 0x%x\n",
3989 				    info->control.flags);
3990 			ieee80211_free_txskb(ar->hw, skb);
3991 			continue;
3992 		}
3993 
3994 		arvif = ath11k_vif_to_arvif(info->control.vif);
3995 		if (ar->allocated_vdev_map & (1LL << arvif->vdev_id) &&
3996 		    arvif->is_started) {
3997 			ret = ath11k_mac_mgmt_tx_wmi(ar, arvif, skb);
3998 			if (ret) {
3999 				ath11k_warn(ar->ab, "failed to tx mgmt frame, vdev_id %d :%d\n",
4000 					    arvif->vdev_id, ret);
4001 				ieee80211_free_txskb(ar->hw, skb);
4002 			} else {
4003 				atomic_inc(&ar->num_pending_mgmt_tx);
4004 			}
4005 		} else {
4006 			ath11k_warn(ar->ab,
4007 				    "dropping mgmt frame for vdev %d, flags 0x%x is_started %d\n",
4008 				    arvif->vdev_id, info->control.flags,
4009 				    arvif->is_started);
4010 			ieee80211_free_txskb(ar->hw, skb);
4011 		}
4012 	}
4013 }
4014 
4015 static int ath11k_mac_mgmt_tx(struct ath11k *ar, struct sk_buff *skb,
4016 			      bool is_prb_rsp)
4017 {
4018 	struct sk_buff_head *q = &ar->wmi_mgmt_tx_queue;
4019 
4020 	if (test_bit(ATH11K_FLAG_CRASH_FLUSH, &ar->ab->dev_flags))
4021 		return -ESHUTDOWN;
4022 
4023 	/* Drop probe response packets when the pending management tx
4024 	 * count has reached a certain threshold, so as to prioritize
4025 	 * other mgmt packets like auth and assoc to be sent on time
4026 	 * for establishing successful connections.
4027 	 */
4028 	if (is_prb_rsp &&
4029 	    atomic_read(&ar->num_pending_mgmt_tx) > ATH11K_PRB_RSP_DROP_THRESHOLD) {
4030 		ath11k_warn(ar->ab,
4031 			    "dropping probe response as pending queue is almost full\n");
4032 		return -ENOSPC;
4033 	}
4034 
4035 	if (skb_queue_len(q) == ATH11K_TX_MGMT_NUM_PENDING_MAX) {
4036 		ath11k_warn(ar->ab, "mgmt tx queue is full\n");
4037 		return -ENOSPC;
4038 	}
4039 
4040 	skb_queue_tail(q, skb);
4041 	ieee80211_queue_work(ar->hw, &ar->wmi_mgmt_tx_work);
4042 
4043 	return 0;
4044 }
4045 
4046 static void ath11k_mac_op_tx(struct ieee80211_hw *hw,
4047 			     struct ieee80211_tx_control *control,
4048 			     struct sk_buff *skb)
4049 {
4050 	struct ath11k_skb_cb *skb_cb = ATH11K_SKB_CB(skb);
4051 	struct ath11k *ar = hw->priv;
4052 	struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
4053 	struct ieee80211_vif *vif = info->control.vif;
4054 	struct ath11k_vif *arvif = ath11k_vif_to_arvif(vif);
4055 	struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data;
4056 	bool is_prb_rsp;
4057 	int ret;
4058 
4059 	if (info->flags & IEEE80211_TX_CTL_HW_80211_ENCAP) {
4060 		skb_cb->flags |= ATH11K_SKB_HW_80211_ENCAP;
4061 	} else if (ieee80211_is_mgmt(hdr->frame_control)) {
4062 		is_prb_rsp = ieee80211_is_probe_resp(hdr->frame_control);
4063 		ret = ath11k_mac_mgmt_tx(ar, skb, is_prb_rsp);
4064 		if (ret) {
4065 			ath11k_warn(ar->ab, "failed to queue management frame %d\n",
4066 				    ret);
4067 			ieee80211_free_txskb(ar->hw, skb);
4068 		}
4069 		return;
4070 	}
4071 
4072 	ret = ath11k_dp_tx(ar, arvif, skb);
4073 	if (ret) {
4074 		ath11k_warn(ar->ab, "failed to transmit frame %d\n", ret);
4075 		ieee80211_free_txskb(ar->hw, skb);
4076 	}
4077 }
4078 
4079 void ath11k_mac_drain_tx(struct ath11k *ar)
4080 {
4081 	/* make sure rcu-protected mac80211 tx path itself is drained */
4082 	synchronize_net();
4083 
4084 	cancel_work_sync(&ar->wmi_mgmt_tx_work);
4085 	ath11k_mgmt_over_wmi_tx_purge(ar);
4086 }
4087 
4088 static int ath11k_mac_config_mon_status_default(struct ath11k *ar, bool enable)
4089 {
4090 	struct htt_rx_ring_tlv_filter tlv_filter = {0};
4091 	struct ath11k_base *ab = ar->ab;
4092 	int i, ret = 0;
4093 	u32 ring_id;
4094 
4095 	if (enable) {
4096 		tlv_filter = ath11k_mac_mon_status_filter_default;
4097 		tlv_filter.rx_filter = ath11k_debugfs_rx_filter(ar);
4098 	}
4099 
4100 	for (i = 0; i < ab->hw_params.num_rxmda_per_pdev; i++) {
4101 		ring_id = ar->dp.rx_mon_status_refill_ring[i].refill_buf_ring.ring_id;
4102 		ret = ath11k_dp_tx_htt_rx_filter_setup(ar->ab, ring_id,
4103 						       ar->dp.mac_id + i,
4104 						       HAL_RXDMA_MONITOR_STATUS,
4105 						       DP_RX_BUFFER_SIZE,
4106 						       &tlv_filter);
4107 	}
4108 
4109 	return ret;
4110 }
4111 
4112 static int ath11k_mac_op_start(struct ieee80211_hw *hw)
4113 {
4114 	struct ath11k *ar = hw->priv;
4115 	struct ath11k_base *ab = ar->ab;
4116 	struct ath11k_pdev *pdev = ar->pdev;
4117 	int ret;
4118 
4119 	ath11k_mac_drain_tx(ar);
4120 	mutex_lock(&ar->conf_mutex);
4121 
4122 	switch (ar->state) {
4123 	case ATH11K_STATE_OFF:
4124 		ar->state = ATH11K_STATE_ON;
4125 		break;
4126 	case ATH11K_STATE_RESTARTING:
4127 		ar->state = ATH11K_STATE_RESTARTED;
4128 		break;
4129 	case ATH11K_STATE_RESTARTED:
4130 	case ATH11K_STATE_WEDGED:
4131 	case ATH11K_STATE_ON:
4132 		WARN_ON(1);
4133 		ret = -EINVAL;
4134 		goto err;
4135 	}
4136 
4137 	ret = ath11k_wmi_pdev_set_param(ar, WMI_PDEV_PARAM_PMF_QOS,
4138 					1, pdev->pdev_id);
4139 
4140 	if (ret) {
4141 		ath11k_err(ar->ab, "failed to enable PMF QOS: (%d\n", ret);
4142 		goto err;
4143 	}
4144 
4145 	ret = ath11k_wmi_pdev_set_param(ar, WMI_PDEV_PARAM_DYNAMIC_BW, 1,
4146 					pdev->pdev_id);
4147 	if (ret) {
4148 		ath11k_err(ar->ab, "failed to enable dynamic bw: %d\n", ret);
4149 		goto err;
4150 	}
4151 
4152 	ret = ath11k_wmi_pdev_set_param(ar, WMI_PDEV_PARAM_ARP_AC_OVERRIDE,
4153 					0, pdev->pdev_id);
4154 	if (ret) {
4155 		ath11k_err(ab, "failed to set ac override for ARP: %d\n",
4156 			   ret);
4157 		goto err;
4158 	}
4159 
4160 	ret = ath11k_wmi_send_dfs_phyerr_offload_enable_cmd(ar, pdev->pdev_id);
4161 	if (ret) {
4162 		ath11k_err(ab, "failed to offload radar detection: %d\n",
4163 			   ret);
4164 		goto err;
4165 	}
4166 
4167 	ret = ath11k_dp_tx_htt_h2t_ppdu_stats_req(ar,
4168 						  HTT_PPDU_STATS_TAG_DEFAULT);
4169 	if (ret) {
4170 		ath11k_err(ab, "failed to req ppdu stats: %d\n", ret);
4171 		goto err;
4172 	}
4173 
4174 	ret = ath11k_wmi_pdev_set_param(ar, WMI_PDEV_PARAM_MESH_MCAST_ENABLE,
4175 					1, pdev->pdev_id);
4176 
4177 	if (ret) {
4178 		ath11k_err(ar->ab, "failed to enable MESH MCAST ENABLE: (%d\n", ret);
4179 		goto err;
4180 	}
4181 
4182 	__ath11k_set_antenna(ar, ar->cfg_tx_chainmask, ar->cfg_rx_chainmask);
4183 
4184 	/* TODO: Do we need to enable ANI? */
4185 
4186 	ath11k_reg_update_chan_list(ar);
4187 
4188 	ar->num_started_vdevs = 0;
4189 	ar->num_created_vdevs = 0;
4190 	ar->num_peers = 0;
4191 	ar->allocated_vdev_map = 0;
4192 
4193 	/* Configure monitor status ring with default rx_filter to get rx status
4194 	 * such as rssi, rx_duration.
4195 	 */
4196 	ret = ath11k_mac_config_mon_status_default(ar, true);
4197 	if (ret) {
4198 		ath11k_err(ab, "failed to configure monitor status ring with default rx_filter: (%d)\n",
4199 			   ret);
4200 		goto err;
4201 	}
4202 
4203 	/* Configure the hash seed for hash based reo dest ring selection */
4204 	ath11k_wmi_pdev_lro_cfg(ar, ar->pdev->pdev_id);
4205 
4206 	mutex_unlock(&ar->conf_mutex);
4207 
4208 	rcu_assign_pointer(ab->pdevs_active[ar->pdev_idx],
4209 			   &ab->pdevs[ar->pdev_idx]);
4210 
4211 	/* allow device to enter IMPS */
4212 	if (ab->hw_params.idle_ps) {
4213 		ret = ath11k_wmi_pdev_set_param(ar, WMI_PDEV_PARAM_IDLE_PS_CONFIG,
4214 						1, pdev->pdev_id);
4215 		if (ret) {
4216 			ath11k_err(ab, "failed to enable idle ps: %d\n", ret);
4217 			goto err;
4218 		}
4219 	}
4220 	return 0;
4221 
4222 err:
4223 	ar->state = ATH11K_STATE_OFF;
4224 	mutex_unlock(&ar->conf_mutex);
4225 
4226 	return ret;
4227 }
4228 
4229 static void ath11k_mac_op_stop(struct ieee80211_hw *hw)
4230 {
4231 	struct ath11k *ar = hw->priv;
4232 	struct htt_ppdu_stats_info *ppdu_stats, *tmp;
4233 	int ret;
4234 
4235 	ath11k_mac_drain_tx(ar);
4236 
4237 	mutex_lock(&ar->conf_mutex);
4238 	ret = ath11k_mac_config_mon_status_default(ar, false);
4239 	if (ret)
4240 		ath11k_err(ar->ab, "failed to clear rx_filter for monitor status ring: (%d)\n",
4241 			   ret);
4242 
4243 	clear_bit(ATH11K_CAC_RUNNING, &ar->dev_flags);
4244 	ar->state = ATH11K_STATE_OFF;
4245 	mutex_unlock(&ar->conf_mutex);
4246 
4247 	cancel_delayed_work_sync(&ar->scan.timeout);
4248 	cancel_work_sync(&ar->regd_update_work);
4249 
4250 	spin_lock_bh(&ar->data_lock);
4251 	list_for_each_entry_safe(ppdu_stats, tmp, &ar->ppdu_stats_info, list) {
4252 		list_del(&ppdu_stats->list);
4253 		kfree(ppdu_stats);
4254 	}
4255 	spin_unlock_bh(&ar->data_lock);
4256 
4257 	rcu_assign_pointer(ar->ab->pdevs_active[ar->pdev_idx], NULL);
4258 
4259 	synchronize_rcu();
4260 
4261 	atomic_set(&ar->num_pending_mgmt_tx, 0);
4262 }
4263 
4264 static void
4265 ath11k_mac_setup_vdev_create_params(struct ath11k_vif *arvif,
4266 				    struct vdev_create_params *params)
4267 {
4268 	struct ath11k *ar = arvif->ar;
4269 	struct ath11k_pdev *pdev = ar->pdev;
4270 
4271 	params->if_id = arvif->vdev_id;
4272 	params->type = arvif->vdev_type;
4273 	params->subtype = arvif->vdev_subtype;
4274 	params->pdev_id = pdev->pdev_id;
4275 
4276 	if (pdev->cap.supported_bands & WMI_HOST_WLAN_2G_CAP) {
4277 		params->chains[NL80211_BAND_2GHZ].tx = ar->num_tx_chains;
4278 		params->chains[NL80211_BAND_2GHZ].rx = ar->num_rx_chains;
4279 	}
4280 	if (pdev->cap.supported_bands & WMI_HOST_WLAN_5G_CAP) {
4281 		params->chains[NL80211_BAND_5GHZ].tx = ar->num_tx_chains;
4282 		params->chains[NL80211_BAND_5GHZ].rx = ar->num_rx_chains;
4283 	}
4284 	if (pdev->cap.supported_bands & WMI_HOST_WLAN_5G_CAP &&
4285 	    ar->supports_6ghz) {
4286 		params->chains[NL80211_BAND_6GHZ].tx = ar->num_tx_chains;
4287 		params->chains[NL80211_BAND_6GHZ].rx = ar->num_rx_chains;
4288 	}
4289 }
4290 
4291 static u32
4292 ath11k_mac_prepare_he_mode(struct ath11k_pdev *pdev, u32 viftype)
4293 {
4294 	struct ath11k_pdev_cap *pdev_cap = &pdev->cap;
4295 	struct ath11k_band_cap *cap_band = NULL;
4296 	u32 *hecap_phy_ptr = NULL;
4297 	u32 hemode = 0;
4298 
4299 	if (pdev->cap.supported_bands & WMI_HOST_WLAN_2G_CAP)
4300 		cap_band = &pdev_cap->band[NL80211_BAND_2GHZ];
4301 	else
4302 		cap_band = &pdev_cap->band[NL80211_BAND_5GHZ];
4303 
4304 	hecap_phy_ptr = &cap_band->he_cap_phy_info[0];
4305 
4306 	hemode = FIELD_PREP(HE_MODE_SU_TX_BFEE, HE_SU_BFEE_ENABLE) |
4307 		 FIELD_PREP(HE_MODE_SU_TX_BFER, HECAP_PHY_SUBFMR_GET(hecap_phy_ptr)) |
4308 		 FIELD_PREP(HE_MODE_UL_MUMIMO, HECAP_PHY_ULMUMIMO_GET(hecap_phy_ptr));
4309 
4310 	/* TODO WDS and other modes */
4311 	if (viftype == NL80211_IFTYPE_AP) {
4312 		hemode |= FIELD_PREP(HE_MODE_MU_TX_BFER,
4313 			  HECAP_PHY_MUBFMR_GET(hecap_phy_ptr)) |
4314 			  FIELD_PREP(HE_MODE_DL_OFDMA, HE_DL_MUOFDMA_ENABLE) |
4315 			  FIELD_PREP(HE_MODE_UL_OFDMA, HE_UL_MUOFDMA_ENABLE);
4316 	} else {
4317 		hemode |= FIELD_PREP(HE_MODE_MU_TX_BFEE, HE_MU_BFEE_ENABLE);
4318 	}
4319 
4320 	return hemode;
4321 }
4322 
4323 static int ath11k_set_he_mu_sounding_mode(struct ath11k *ar,
4324 					  struct ath11k_vif *arvif)
4325 {
4326 	u32 param_id, param_value;
4327 	struct ath11k_base *ab = ar->ab;
4328 	int ret = 0;
4329 
4330 	param_id = WMI_VDEV_PARAM_SET_HEMU_MODE;
4331 	param_value = ath11k_mac_prepare_he_mode(ar->pdev, arvif->vif->type);
4332 	ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
4333 					    param_id, param_value);
4334 	if (ret) {
4335 		ath11k_warn(ab, "failed to set vdev %d HE MU mode: %d param_value %x\n",
4336 			    arvif->vdev_id, ret, param_value);
4337 		return ret;
4338 	}
4339 	param_id = WMI_VDEV_PARAM_SET_HE_SOUNDING_MODE;
4340 	param_value =
4341 		FIELD_PREP(HE_VHT_SOUNDING_MODE, HE_VHT_SOUNDING_MODE_ENABLE) |
4342 		FIELD_PREP(HE_TRIG_NONTRIG_SOUNDING_MODE,
4343 			   HE_TRIG_NONTRIG_SOUNDING_MODE_ENABLE);
4344 	ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
4345 					    param_id, param_value);
4346 	if (ret) {
4347 		ath11k_warn(ab, "failed to set vdev %d HE MU mode: %d\n",
4348 			    arvif->vdev_id, ret);
4349 		return ret;
4350 	}
4351 	return ret;
4352 }
4353 
4354 static void ath11k_mac_op_update_vif_offload(struct ieee80211_hw *hw,
4355 					     struct ieee80211_vif *vif)
4356 {
4357 	struct ath11k *ar = hw->priv;
4358 	struct ath11k_base *ab = ar->ab;
4359 	struct ath11k_vif *arvif = ath11k_vif_to_arvif(vif);
4360 	u32 param_id, param_value;
4361 	int ret;
4362 
4363 	param_id = WMI_VDEV_PARAM_TX_ENCAP_TYPE;
4364 	if (ath11k_frame_mode != ATH11K_HW_TXRX_ETHERNET ||
4365 	    (vif->type != NL80211_IFTYPE_STATION &&
4366 	     vif->type != NL80211_IFTYPE_AP))
4367 		vif->offload_flags &= ~IEEE80211_OFFLOAD_ENCAP_ENABLED;
4368 
4369 	if (vif->offload_flags & IEEE80211_OFFLOAD_ENCAP_ENABLED)
4370 		param_value = ATH11K_HW_TXRX_ETHERNET;
4371 	else if (test_bit(ATH11K_FLAG_RAW_MODE, &ab->dev_flags))
4372 		param_value = ATH11K_HW_TXRX_RAW;
4373 	else
4374 		param_value = ATH11K_HW_TXRX_NATIVE_WIFI;
4375 
4376 	ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
4377 					    param_id, param_value);
4378 	if (ret) {
4379 		ath11k_warn(ab, "failed to set vdev %d tx encap mode: %d\n",
4380 			    arvif->vdev_id, ret);
4381 		vif->offload_flags &= ~IEEE80211_OFFLOAD_ENCAP_ENABLED;
4382 	}
4383 }
4384 
4385 static int ath11k_mac_op_add_interface(struct ieee80211_hw *hw,
4386 				       struct ieee80211_vif *vif)
4387 {
4388 	struct ath11k *ar = hw->priv;
4389 	struct ath11k_base *ab = ar->ab;
4390 	struct ath11k_vif *arvif = ath11k_vif_to_arvif(vif);
4391 	struct vdev_create_params vdev_param = {0};
4392 	struct peer_create_params peer_param;
4393 	u32 param_id, param_value;
4394 	u16 nss;
4395 	int i;
4396 	int ret;
4397 	int bit;
4398 
4399 	vif->driver_flags |= IEEE80211_VIF_SUPPORTS_UAPSD;
4400 
4401 	mutex_lock(&ar->conf_mutex);
4402 
4403 	if (vif->type == NL80211_IFTYPE_AP &&
4404 	    ar->num_peers > (ar->max_num_peers - 1)) {
4405 		ath11k_warn(ab, "failed to create vdev due to insufficient peer entry resource in firmware\n");
4406 		ret = -ENOBUFS;
4407 		goto err;
4408 	}
4409 
4410 	if (ar->num_created_vdevs > (TARGET_NUM_VDEVS - 1)) {
4411 		ath11k_warn(ab, "failed to create vdev, reached max vdev limit %d\n",
4412 			    TARGET_NUM_VDEVS);
4413 		ret = -EBUSY;
4414 		goto err;
4415 	}
4416 
4417 	memset(arvif, 0, sizeof(*arvif));
4418 
4419 	arvif->ar = ar;
4420 	arvif->vif = vif;
4421 
4422 	INIT_LIST_HEAD(&arvif->list);
4423 
4424 	/* Should we initialize any worker to handle connection loss indication
4425 	 * from firmware in sta mode?
4426 	 */
4427 
4428 	for (i = 0; i < ARRAY_SIZE(arvif->bitrate_mask.control); i++) {
4429 		arvif->bitrate_mask.control[i].legacy = 0xffffffff;
4430 		memset(arvif->bitrate_mask.control[i].ht_mcs, 0xff,
4431 		       sizeof(arvif->bitrate_mask.control[i].ht_mcs));
4432 		memset(arvif->bitrate_mask.control[i].vht_mcs, 0xff,
4433 		       sizeof(arvif->bitrate_mask.control[i].vht_mcs));
4434 	}
4435 
4436 	bit = __ffs64(ab->free_vdev_map);
4437 
4438 	arvif->vdev_id = bit;
4439 	arvif->vdev_subtype = WMI_VDEV_SUBTYPE_NONE;
4440 
4441 	switch (vif->type) {
4442 	case NL80211_IFTYPE_UNSPECIFIED:
4443 	case NL80211_IFTYPE_STATION:
4444 		arvif->vdev_type = WMI_VDEV_TYPE_STA;
4445 		break;
4446 	case NL80211_IFTYPE_MESH_POINT:
4447 		arvif->vdev_subtype = WMI_VDEV_SUBTYPE_MESH_11S;
4448 		fallthrough;
4449 	case NL80211_IFTYPE_AP:
4450 		arvif->vdev_type = WMI_VDEV_TYPE_AP;
4451 		break;
4452 	case NL80211_IFTYPE_MONITOR:
4453 		arvif->vdev_type = WMI_VDEV_TYPE_MONITOR;
4454 		break;
4455 	default:
4456 		WARN_ON(1);
4457 		break;
4458 	}
4459 
4460 	ath11k_dbg(ar->ab, ATH11K_DBG_MAC, "mac add interface id %d type %d subtype %d map %llx\n",
4461 		   arvif->vdev_id, arvif->vdev_type, arvif->vdev_subtype,
4462 		   ab->free_vdev_map);
4463 
4464 	vif->cab_queue = arvif->vdev_id % (ATH11K_HW_MAX_QUEUES - 1);
4465 	for (i = 0; i < ARRAY_SIZE(vif->hw_queue); i++)
4466 		vif->hw_queue[i] = i % (ATH11K_HW_MAX_QUEUES - 1);
4467 
4468 	ath11k_mac_setup_vdev_create_params(arvif, &vdev_param);
4469 
4470 	ret = ath11k_wmi_vdev_create(ar, vif->addr, &vdev_param);
4471 	if (ret) {
4472 		ath11k_warn(ab, "failed to create WMI vdev %d: %d\n",
4473 			    arvif->vdev_id, ret);
4474 		goto err;
4475 	}
4476 
4477 	ar->num_created_vdevs++;
4478 	ath11k_dbg(ab, ATH11K_DBG_MAC, "vdev %pM created, vdev_id %d\n",
4479 		   vif->addr, arvif->vdev_id);
4480 	ar->allocated_vdev_map |= 1LL << arvif->vdev_id;
4481 	ab->free_vdev_map &= ~(1LL << arvif->vdev_id);
4482 
4483 	spin_lock_bh(&ar->data_lock);
4484 	list_add(&arvif->list, &ar->arvifs);
4485 	spin_unlock_bh(&ar->data_lock);
4486 
4487 	ath11k_mac_op_update_vif_offload(hw, vif);
4488 
4489 	nss = get_num_chains(ar->cfg_tx_chainmask) ? : 1;
4490 	ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
4491 					    WMI_VDEV_PARAM_NSS, nss);
4492 	if (ret) {
4493 		ath11k_warn(ab, "failed to set vdev %d chainmask 0x%x, nss %d :%d\n",
4494 			    arvif->vdev_id, ar->cfg_tx_chainmask, nss, ret);
4495 		goto err_vdev_del;
4496 	}
4497 
4498 	switch (arvif->vdev_type) {
4499 	case WMI_VDEV_TYPE_AP:
4500 		peer_param.vdev_id = arvif->vdev_id;
4501 		peer_param.peer_addr = vif->addr;
4502 		peer_param.peer_type = WMI_PEER_TYPE_DEFAULT;
4503 		ret = ath11k_peer_create(ar, arvif, NULL, &peer_param);
4504 		if (ret) {
4505 			ath11k_warn(ab, "failed to vdev %d create peer for AP: %d\n",
4506 				    arvif->vdev_id, ret);
4507 			goto err_vdev_del;
4508 		}
4509 
4510 		ret = ath11k_mac_set_kickout(arvif);
4511 		if (ret) {
4512 			ath11k_warn(ar->ab, "failed to set vdev %i kickout parameters: %d\n",
4513 				    arvif->vdev_id, ret);
4514 			goto err_peer_del;
4515 		}
4516 		break;
4517 	case WMI_VDEV_TYPE_STA:
4518 		param_id = WMI_STA_PS_PARAM_RX_WAKE_POLICY;
4519 		param_value = WMI_STA_PS_RX_WAKE_POLICY_WAKE;
4520 		ret = ath11k_wmi_set_sta_ps_param(ar, arvif->vdev_id,
4521 						  param_id, param_value);
4522 		if (ret) {
4523 			ath11k_warn(ar->ab, "failed to set vdev %d RX wake policy: %d\n",
4524 				    arvif->vdev_id, ret);
4525 			goto err_peer_del;
4526 		}
4527 
4528 		param_id = WMI_STA_PS_PARAM_TX_WAKE_THRESHOLD;
4529 		param_value = WMI_STA_PS_TX_WAKE_THRESHOLD_ALWAYS;
4530 		ret = ath11k_wmi_set_sta_ps_param(ar, arvif->vdev_id,
4531 						  param_id, param_value);
4532 		if (ret) {
4533 			ath11k_warn(ar->ab, "failed to set vdev %d TX wake threshold: %d\n",
4534 				    arvif->vdev_id, ret);
4535 			goto err_peer_del;
4536 		}
4537 
4538 		param_id = WMI_STA_PS_PARAM_PSPOLL_COUNT;
4539 		param_value = WMI_STA_PS_PSPOLL_COUNT_NO_MAX;
4540 		ret = ath11k_wmi_set_sta_ps_param(ar, arvif->vdev_id,
4541 						  param_id, param_value);
4542 		if (ret) {
4543 			ath11k_warn(ar->ab, "failed to set vdev %d pspoll count: %d\n",
4544 				    arvif->vdev_id, ret);
4545 			goto err_peer_del;
4546 		}
4547 
4548 		ret = ath11k_wmi_pdev_set_ps_mode(ar, arvif->vdev_id, false);
4549 		if (ret) {
4550 			ath11k_warn(ar->ab, "failed to disable vdev %d ps mode: %d\n",
4551 				    arvif->vdev_id, ret);
4552 			goto err_peer_del;
4553 		}
4554 		break;
4555 	default:
4556 		break;
4557 	}
4558 
4559 	arvif->txpower = vif->bss_conf.txpower;
4560 	ret = ath11k_mac_txpower_recalc(ar);
4561 	if (ret)
4562 		goto err_peer_del;
4563 
4564 	param_id = WMI_VDEV_PARAM_RTS_THRESHOLD;
4565 	param_value = ar->hw->wiphy->rts_threshold;
4566 	ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
4567 					    param_id, param_value);
4568 	if (ret) {
4569 		ath11k_warn(ar->ab, "failed to set rts threshold for vdev %d: %d\n",
4570 			    arvif->vdev_id, ret);
4571 	}
4572 
4573 	ath11k_dp_vdev_tx_attach(ar, arvif);
4574 
4575 	mutex_unlock(&ar->conf_mutex);
4576 
4577 	return 0;
4578 
4579 err_peer_del:
4580 	if (arvif->vdev_type == WMI_VDEV_TYPE_AP) {
4581 		ar->num_peers--;
4582 		ath11k_wmi_send_peer_delete_cmd(ar, vif->addr, arvif->vdev_id);
4583 	}
4584 
4585 err_vdev_del:
4586 	ath11k_wmi_vdev_delete(ar, arvif->vdev_id);
4587 	ar->num_created_vdevs--;
4588 	ar->allocated_vdev_map &= ~(1LL << arvif->vdev_id);
4589 	ab->free_vdev_map |= 1LL << arvif->vdev_id;
4590 	spin_lock_bh(&ar->data_lock);
4591 	list_del(&arvif->list);
4592 	spin_unlock_bh(&ar->data_lock);
4593 
4594 err:
4595 	mutex_unlock(&ar->conf_mutex);
4596 
4597 	return ret;
4598 }
4599 
4600 static int ath11k_mac_vif_unref(int buf_id, void *skb, void *ctx)
4601 {
4602 	struct ieee80211_vif *vif = (struct ieee80211_vif *)ctx;
4603 	struct ath11k_skb_cb *skb_cb = ATH11K_SKB_CB((struct sk_buff *)skb);
4604 
4605 	if (skb_cb->vif == vif)
4606 		skb_cb->vif = NULL;
4607 
4608 	return 0;
4609 }
4610 
4611 static void ath11k_mac_op_remove_interface(struct ieee80211_hw *hw,
4612 					   struct ieee80211_vif *vif)
4613 {
4614 	struct ath11k *ar = hw->priv;
4615 	struct ath11k_vif *arvif = ath11k_vif_to_arvif(vif);
4616 	struct ath11k_base *ab = ar->ab;
4617 	int ret;
4618 	int i;
4619 
4620 	mutex_lock(&ar->conf_mutex);
4621 
4622 	ath11k_dbg(ab, ATH11K_DBG_MAC, "mac remove interface (vdev %d)\n",
4623 		   arvif->vdev_id);
4624 
4625 	spin_lock_bh(&ar->data_lock);
4626 	list_del(&arvif->list);
4627 	spin_unlock_bh(&ar->data_lock);
4628 
4629 	if (arvif->vdev_type == WMI_VDEV_TYPE_AP) {
4630 		ret = ath11k_peer_delete(ar, arvif->vdev_id, vif->addr);
4631 		if (ret)
4632 			ath11k_warn(ab, "failed to submit AP self-peer removal on vdev %d: %d\n",
4633 				    arvif->vdev_id, ret);
4634 	}
4635 
4636 	ret = ath11k_wmi_vdev_delete(ar, arvif->vdev_id);
4637 	if (ret)
4638 		ath11k_warn(ab, "failed to delete WMI vdev %d: %d\n",
4639 			    arvif->vdev_id, ret);
4640 
4641 	ar->num_created_vdevs--;
4642 	ath11k_dbg(ab, ATH11K_DBG_MAC, "vdev %pM deleted, vdev_id %d\n",
4643 		   vif->addr, arvif->vdev_id);
4644 	ar->allocated_vdev_map &= ~(1LL << arvif->vdev_id);
4645 	ab->free_vdev_map |= 1LL << (arvif->vdev_id);
4646 
4647 	ath11k_peer_cleanup(ar, arvif->vdev_id);
4648 
4649 	idr_for_each(&ar->txmgmt_idr,
4650 		     ath11k_mac_vif_txmgmt_idr_remove, vif);
4651 
4652 	for (i = 0; i < DP_TCL_NUM_RING_MAX; i++) {
4653 		spin_lock_bh(&ab->dp.tx_ring[i].tx_idr_lock);
4654 		idr_for_each(&ab->dp.tx_ring[i].txbuf_idr,
4655 			     ath11k_mac_vif_unref, vif);
4656 		spin_unlock_bh(&ab->dp.tx_ring[i].tx_idr_lock);
4657 	}
4658 
4659 	/* Recalc txpower for remaining vdev */
4660 	ath11k_mac_txpower_recalc(ar);
4661 	clear_bit(ATH11K_FLAG_MONITOR_ENABLED, &ar->monitor_flags);
4662 
4663 	/* TODO: recal traffic pause state based on the available vdevs */
4664 
4665 	mutex_unlock(&ar->conf_mutex);
4666 }
4667 
4668 /* FIXME: Has to be verified. */
4669 #define SUPPORTED_FILTERS			\
4670 	(FIF_ALLMULTI |				\
4671 	FIF_CONTROL |				\
4672 	FIF_PSPOLL |				\
4673 	FIF_OTHER_BSS |				\
4674 	FIF_BCN_PRBRESP_PROMISC |		\
4675 	FIF_PROBE_REQ |				\
4676 	FIF_FCSFAIL)
4677 
4678 static void ath11k_mac_op_configure_filter(struct ieee80211_hw *hw,
4679 					   unsigned int changed_flags,
4680 					   unsigned int *total_flags,
4681 					   u64 multicast)
4682 {
4683 	struct ath11k *ar = hw->priv;
4684 	bool reset_flag = false;
4685 	int ret = 0;
4686 
4687 	mutex_lock(&ar->conf_mutex);
4688 
4689 	changed_flags &= SUPPORTED_FILTERS;
4690 	*total_flags &= SUPPORTED_FILTERS;
4691 	ar->filter_flags = *total_flags;
4692 
4693 	/* For monitor mode */
4694 	reset_flag = !(ar->filter_flags & FIF_BCN_PRBRESP_PROMISC);
4695 
4696 	ret = ath11k_dp_tx_htt_monitor_mode_ring_config(ar, reset_flag);
4697 	if (!ret) {
4698 		if (!reset_flag)
4699 			set_bit(ATH11K_FLAG_MONITOR_ENABLED, &ar->monitor_flags);
4700 		else
4701 			clear_bit(ATH11K_FLAG_MONITOR_ENABLED, &ar->monitor_flags);
4702 	} else {
4703 		ath11k_warn(ar->ab,
4704 			    "fail to set monitor filter: %d\n", ret);
4705 	}
4706 	ath11k_dbg(ar->ab, ATH11K_DBG_MAC,
4707 		   "changed_flags:0x%x, total_flags:0x%x, reset_flag:%d\n",
4708 		   changed_flags, *total_flags, reset_flag);
4709 
4710 	mutex_unlock(&ar->conf_mutex);
4711 }
4712 
4713 static int ath11k_mac_op_get_antenna(struct ieee80211_hw *hw, u32 *tx_ant, u32 *rx_ant)
4714 {
4715 	struct ath11k *ar = hw->priv;
4716 
4717 	mutex_lock(&ar->conf_mutex);
4718 
4719 	*tx_ant = ar->cfg_tx_chainmask;
4720 	*rx_ant = ar->cfg_rx_chainmask;
4721 
4722 	mutex_unlock(&ar->conf_mutex);
4723 
4724 	return 0;
4725 }
4726 
4727 static int ath11k_mac_op_set_antenna(struct ieee80211_hw *hw, u32 tx_ant, u32 rx_ant)
4728 {
4729 	struct ath11k *ar = hw->priv;
4730 	int ret;
4731 
4732 	mutex_lock(&ar->conf_mutex);
4733 	ret = __ath11k_set_antenna(ar, tx_ant, rx_ant);
4734 	mutex_unlock(&ar->conf_mutex);
4735 
4736 	return ret;
4737 }
4738 
4739 static int ath11k_mac_op_ampdu_action(struct ieee80211_hw *hw,
4740 				      struct ieee80211_vif *vif,
4741 				      struct ieee80211_ampdu_params *params)
4742 {
4743 	struct ath11k *ar = hw->priv;
4744 	int ret = -EINVAL;
4745 
4746 	mutex_lock(&ar->conf_mutex);
4747 
4748 	switch (params->action) {
4749 	case IEEE80211_AMPDU_RX_START:
4750 		ret = ath11k_dp_rx_ampdu_start(ar, params);
4751 		break;
4752 	case IEEE80211_AMPDU_RX_STOP:
4753 		ret = ath11k_dp_rx_ampdu_stop(ar, params);
4754 		break;
4755 	case IEEE80211_AMPDU_TX_START:
4756 	case IEEE80211_AMPDU_TX_STOP_CONT:
4757 	case IEEE80211_AMPDU_TX_STOP_FLUSH:
4758 	case IEEE80211_AMPDU_TX_STOP_FLUSH_CONT:
4759 	case IEEE80211_AMPDU_TX_OPERATIONAL:
4760 		/* Tx A-MPDU aggregation offloaded to hw/fw so deny mac80211
4761 		 * Tx aggregation requests.
4762 		 */
4763 		ret = -EOPNOTSUPP;
4764 		break;
4765 	}
4766 
4767 	mutex_unlock(&ar->conf_mutex);
4768 
4769 	return ret;
4770 }
4771 
4772 static int ath11k_mac_op_add_chanctx(struct ieee80211_hw *hw,
4773 				     struct ieee80211_chanctx_conf *ctx)
4774 {
4775 	struct ath11k *ar = hw->priv;
4776 	struct ath11k_base *ab = ar->ab;
4777 
4778 	ath11k_dbg(ab, ATH11K_DBG_MAC,
4779 		   "mac chanctx add freq %hu width %d ptr %pK\n",
4780 		   ctx->def.chan->center_freq, ctx->def.width, ctx);
4781 
4782 	mutex_lock(&ar->conf_mutex);
4783 
4784 	spin_lock_bh(&ar->data_lock);
4785 	/* TODO: In case of multiple channel context, populate rx_channel from
4786 	 * Rx PPDU desc information.
4787 	 */
4788 	ar->rx_channel = ctx->def.chan;
4789 	spin_unlock_bh(&ar->data_lock);
4790 
4791 	mutex_unlock(&ar->conf_mutex);
4792 
4793 	return 0;
4794 }
4795 
4796 static void ath11k_mac_op_remove_chanctx(struct ieee80211_hw *hw,
4797 					 struct ieee80211_chanctx_conf *ctx)
4798 {
4799 	struct ath11k *ar = hw->priv;
4800 	struct ath11k_base *ab = ar->ab;
4801 
4802 	ath11k_dbg(ab, ATH11K_DBG_MAC,
4803 		   "mac chanctx remove freq %hu width %d ptr %pK\n",
4804 		   ctx->def.chan->center_freq, ctx->def.width, ctx);
4805 
4806 	mutex_lock(&ar->conf_mutex);
4807 
4808 	spin_lock_bh(&ar->data_lock);
4809 	/* TODO: In case of there is one more channel context left, populate
4810 	 * rx_channel with the channel of that remaining channel context.
4811 	 */
4812 	ar->rx_channel = NULL;
4813 	spin_unlock_bh(&ar->data_lock);
4814 
4815 	mutex_unlock(&ar->conf_mutex);
4816 }
4817 
4818 static inline int ath11k_mac_vdev_setup_sync(struct ath11k *ar)
4819 {
4820 	lockdep_assert_held(&ar->conf_mutex);
4821 
4822 	if (test_bit(ATH11K_FLAG_CRASH_FLUSH, &ar->ab->dev_flags))
4823 		return -ESHUTDOWN;
4824 
4825 	if (!wait_for_completion_timeout(&ar->vdev_setup_done,
4826 					 ATH11K_VDEV_SETUP_TIMEOUT_HZ))
4827 		return -ETIMEDOUT;
4828 
4829 	return ar->last_wmi_vdev_start_status ? -EINVAL : 0;
4830 }
4831 
4832 static int
4833 ath11k_mac_vdev_start_restart(struct ath11k_vif *arvif,
4834 			      const struct cfg80211_chan_def *chandef,
4835 			      bool restart)
4836 {
4837 	struct ath11k *ar = arvif->ar;
4838 	struct ath11k_base *ab = ar->ab;
4839 	struct wmi_vdev_start_req_arg arg = {};
4840 	int he_support = arvif->vif->bss_conf.he_support;
4841 	int ret = 0;
4842 
4843 	lockdep_assert_held(&ar->conf_mutex);
4844 
4845 	reinit_completion(&ar->vdev_setup_done);
4846 
4847 	arg.vdev_id = arvif->vdev_id;
4848 	arg.dtim_period = arvif->dtim_period;
4849 	arg.bcn_intval = arvif->beacon_interval;
4850 
4851 	arg.channel.freq = chandef->chan->center_freq;
4852 	arg.channel.band_center_freq1 = chandef->center_freq1;
4853 	arg.channel.band_center_freq2 = chandef->center_freq2;
4854 	arg.channel.mode =
4855 		ath11k_phymodes[chandef->chan->band][chandef->width];
4856 
4857 	arg.channel.min_power = 0;
4858 	arg.channel.max_power = chandef->chan->max_power * 2;
4859 	arg.channel.max_reg_power = chandef->chan->max_reg_power * 2;
4860 	arg.channel.max_antenna_gain = chandef->chan->max_antenna_gain * 2;
4861 
4862 	arg.pref_tx_streams = ar->num_tx_chains;
4863 	arg.pref_rx_streams = ar->num_rx_chains;
4864 
4865 	if (arvif->vdev_type == WMI_VDEV_TYPE_AP) {
4866 		arg.ssid = arvif->u.ap.ssid;
4867 		arg.ssid_len = arvif->u.ap.ssid_len;
4868 		arg.hidden_ssid = arvif->u.ap.hidden_ssid;
4869 
4870 		/* For now allow DFS for AP mode */
4871 		arg.channel.chan_radar =
4872 			!!(chandef->chan->flags & IEEE80211_CHAN_RADAR);
4873 
4874 		arg.channel.passive = arg.channel.chan_radar;
4875 
4876 		spin_lock_bh(&ab->base_lock);
4877 		arg.regdomain = ar->ab->dfs_region;
4878 		spin_unlock_bh(&ab->base_lock);
4879 
4880 		/* TODO: Notify if secondary 80Mhz also needs radar detection */
4881 		if (he_support) {
4882 			ret = ath11k_set_he_mu_sounding_mode(ar, arvif);
4883 			if (ret) {
4884 				ath11k_warn(ar->ab, "failed to set he mode vdev %i\n",
4885 					    arg.vdev_id);
4886 				return ret;
4887 			}
4888 		}
4889 	}
4890 
4891 	arg.channel.passive |= !!(chandef->chan->flags & IEEE80211_CHAN_NO_IR);
4892 
4893 	ath11k_dbg(ab, ATH11K_DBG_MAC,
4894 		   "mac vdev %d start center_freq %d phymode %s\n",
4895 		   arg.vdev_id, arg.channel.freq,
4896 		   ath11k_wmi_phymode_str(arg.channel.mode));
4897 
4898 	ret = ath11k_wmi_vdev_start(ar, &arg, restart);
4899 	if (ret) {
4900 		ath11k_warn(ar->ab, "failed to %s WMI vdev %i\n",
4901 			    restart ? "restart" : "start", arg.vdev_id);
4902 		return ret;
4903 	}
4904 
4905 	ret = ath11k_mac_vdev_setup_sync(ar);
4906 	if (ret) {
4907 		ath11k_warn(ab, "failed to synchronize setup for vdev %i %s: %d\n",
4908 			    arg.vdev_id, restart ? "restart" : "start", ret);
4909 		return ret;
4910 	}
4911 
4912 	ar->num_started_vdevs++;
4913 	ath11k_dbg(ab, ATH11K_DBG_MAC,  "vdev %pM started, vdev_id %d\n",
4914 		   arvif->vif->addr, arvif->vdev_id);
4915 
4916 	/* Enable CAC Flag in the driver by checking the channel DFS cac time,
4917 	 * i.e dfs_cac_ms value which will be valid only for radar channels
4918 	 * and state as NL80211_DFS_USABLE which indicates CAC needs to be
4919 	 * done before channel usage. This flags is used to drop rx packets.
4920 	 * during CAC.
4921 	 */
4922 	/* TODO Set the flag for other interface types as required */
4923 	if (arvif->vdev_type == WMI_VDEV_TYPE_AP &&
4924 	    chandef->chan->dfs_cac_ms &&
4925 	    chandef->chan->dfs_state == NL80211_DFS_USABLE) {
4926 		set_bit(ATH11K_CAC_RUNNING, &ar->dev_flags);
4927 		ath11k_dbg(ab, ATH11K_DBG_MAC,
4928 			   "CAC Started in chan_freq %d for vdev %d\n",
4929 			   arg.channel.freq, arg.vdev_id);
4930 	}
4931 
4932 	ret = ath11k_mac_set_txbf_conf(arvif);
4933 	if (ret)
4934 		ath11k_warn(ab, "failed to set txbf conf for vdev %d: %d\n",
4935 			    arvif->vdev_id, ret);
4936 
4937 	return 0;
4938 }
4939 
4940 static int ath11k_mac_vdev_stop(struct ath11k_vif *arvif)
4941 {
4942 	struct ath11k *ar = arvif->ar;
4943 	int ret;
4944 
4945 	lockdep_assert_held(&ar->conf_mutex);
4946 
4947 	reinit_completion(&ar->vdev_setup_done);
4948 
4949 	spin_lock_bh(&ar->data_lock);
4950 
4951 	ar->vdev_stop_status.stop_in_progress = true;
4952 	ar->vdev_stop_status.vdev_id = arvif->vdev_id;
4953 
4954 	spin_unlock_bh(&ar->data_lock);
4955 
4956 	ret = ath11k_wmi_vdev_stop(ar, arvif->vdev_id);
4957 	if (ret) {
4958 		ath11k_warn(ar->ab, "failed to stop WMI vdev %i: %d\n",
4959 			    arvif->vdev_id, ret);
4960 		goto err;
4961 	}
4962 
4963 	ret = ath11k_mac_vdev_setup_sync(ar);
4964 	if (ret) {
4965 		ath11k_warn(ar->ab, "failed to synchronize setup for vdev %i: %d\n",
4966 			    arvif->vdev_id, ret);
4967 		goto err;
4968 	}
4969 
4970 	WARN_ON(ar->num_started_vdevs == 0);
4971 
4972 	ar->num_started_vdevs--;
4973 	ath11k_dbg(ar->ab, ATH11K_DBG_MAC, "vdev %pM stopped, vdev_id %d\n",
4974 		   arvif->vif->addr, arvif->vdev_id);
4975 
4976 	if (test_bit(ATH11K_CAC_RUNNING, &ar->dev_flags)) {
4977 		clear_bit(ATH11K_CAC_RUNNING, &ar->dev_flags);
4978 		ath11k_dbg(ar->ab, ATH11K_DBG_MAC, "CAC Stopped for vdev %d\n",
4979 			   arvif->vdev_id);
4980 	}
4981 
4982 	return 0;
4983 err:
4984 	spin_lock_bh(&ar->data_lock);
4985 	ar->vdev_stop_status.stop_in_progress = false;
4986 	spin_unlock_bh(&ar->data_lock);
4987 
4988 	return ret;
4989 }
4990 
4991 static int ath11k_mac_vdev_start(struct ath11k_vif *arvif,
4992 				 const struct cfg80211_chan_def *chandef)
4993 {
4994 	return ath11k_mac_vdev_start_restart(arvif, chandef, false);
4995 }
4996 
4997 static int ath11k_mac_vdev_restart(struct ath11k_vif *arvif,
4998 				   const struct cfg80211_chan_def *chandef)
4999 {
5000 	return ath11k_mac_vdev_start_restart(arvif, chandef, true);
5001 }
5002 
5003 struct ath11k_mac_change_chanctx_arg {
5004 	struct ieee80211_chanctx_conf *ctx;
5005 	struct ieee80211_vif_chanctx_switch *vifs;
5006 	int n_vifs;
5007 	int next_vif;
5008 };
5009 
5010 static void
5011 ath11k_mac_change_chanctx_cnt_iter(void *data, u8 *mac,
5012 				   struct ieee80211_vif *vif)
5013 {
5014 	struct ath11k_mac_change_chanctx_arg *arg = data;
5015 
5016 	if (rcu_access_pointer(vif->chanctx_conf) != arg->ctx)
5017 		return;
5018 
5019 	arg->n_vifs++;
5020 }
5021 
5022 static void
5023 ath11k_mac_change_chanctx_fill_iter(void *data, u8 *mac,
5024 				    struct ieee80211_vif *vif)
5025 {
5026 	struct ath11k_mac_change_chanctx_arg *arg = data;
5027 	struct ieee80211_chanctx_conf *ctx;
5028 
5029 	ctx = rcu_access_pointer(vif->chanctx_conf);
5030 	if (ctx != arg->ctx)
5031 		return;
5032 
5033 	if (WARN_ON(arg->next_vif == arg->n_vifs))
5034 		return;
5035 
5036 	arg->vifs[arg->next_vif].vif = vif;
5037 	arg->vifs[arg->next_vif].old_ctx = ctx;
5038 	arg->vifs[arg->next_vif].new_ctx = ctx;
5039 	arg->next_vif++;
5040 }
5041 
5042 static void
5043 ath11k_mac_update_vif_chan(struct ath11k *ar,
5044 			   struct ieee80211_vif_chanctx_switch *vifs,
5045 			   int n_vifs)
5046 {
5047 	struct ath11k_base *ab = ar->ab;
5048 	struct ath11k_vif *arvif;
5049 	int ret;
5050 	int i;
5051 
5052 	lockdep_assert_held(&ar->conf_mutex);
5053 
5054 	for (i = 0; i < n_vifs; i++) {
5055 		arvif = (void *)vifs[i].vif->drv_priv;
5056 
5057 		ath11k_dbg(ab, ATH11K_DBG_MAC,
5058 			   "mac chanctx switch vdev_id %i freq %hu->%hu width %d->%d\n",
5059 			   arvif->vdev_id,
5060 			   vifs[i].old_ctx->def.chan->center_freq,
5061 			   vifs[i].new_ctx->def.chan->center_freq,
5062 			   vifs[i].old_ctx->def.width,
5063 			   vifs[i].new_ctx->def.width);
5064 
5065 		if (WARN_ON(!arvif->is_started))
5066 			continue;
5067 
5068 		if (WARN_ON(!arvif->is_up))
5069 			continue;
5070 
5071 		ret = ath11k_wmi_vdev_down(ar, arvif->vdev_id);
5072 		if (ret) {
5073 			ath11k_warn(ab, "failed to down vdev %d: %d\n",
5074 				    arvif->vdev_id, ret);
5075 			continue;
5076 		}
5077 	}
5078 
5079 	/* All relevant vdevs are downed and associated channel resources
5080 	 * should be available for the channel switch now.
5081 	 */
5082 
5083 	/* TODO: Update ar->rx_channel */
5084 
5085 	for (i = 0; i < n_vifs; i++) {
5086 		arvif = (void *)vifs[i].vif->drv_priv;
5087 
5088 		if (WARN_ON(!arvif->is_started))
5089 			continue;
5090 
5091 		if (WARN_ON(!arvif->is_up))
5092 			continue;
5093 
5094 		ret = ath11k_mac_setup_bcn_tmpl(arvif);
5095 		if (ret)
5096 			ath11k_warn(ab, "failed to update bcn tmpl during csa: %d\n",
5097 				    ret);
5098 
5099 		ret = ath11k_mac_vdev_restart(arvif, &vifs[i].new_ctx->def);
5100 		if (ret) {
5101 			ath11k_warn(ab, "failed to restart vdev %d: %d\n",
5102 				    arvif->vdev_id, ret);
5103 			continue;
5104 		}
5105 
5106 		ret = ath11k_wmi_vdev_up(arvif->ar, arvif->vdev_id, arvif->aid,
5107 					 arvif->bssid);
5108 		if (ret) {
5109 			ath11k_warn(ab, "failed to bring vdev up %d: %d\n",
5110 				    arvif->vdev_id, ret);
5111 			continue;
5112 		}
5113 	}
5114 }
5115 
5116 static void
5117 ath11k_mac_update_active_vif_chan(struct ath11k *ar,
5118 				  struct ieee80211_chanctx_conf *ctx)
5119 {
5120 	struct ath11k_mac_change_chanctx_arg arg = { .ctx = ctx };
5121 
5122 	lockdep_assert_held(&ar->conf_mutex);
5123 
5124 	ieee80211_iterate_active_interfaces_atomic(ar->hw,
5125 						   IEEE80211_IFACE_ITER_NORMAL,
5126 						   ath11k_mac_change_chanctx_cnt_iter,
5127 						   &arg);
5128 	if (arg.n_vifs == 0)
5129 		return;
5130 
5131 	arg.vifs = kcalloc(arg.n_vifs, sizeof(arg.vifs[0]), GFP_KERNEL);
5132 	if (!arg.vifs)
5133 		return;
5134 
5135 	ieee80211_iterate_active_interfaces_atomic(ar->hw,
5136 						   IEEE80211_IFACE_ITER_NORMAL,
5137 						   ath11k_mac_change_chanctx_fill_iter,
5138 						   &arg);
5139 
5140 	ath11k_mac_update_vif_chan(ar, arg.vifs, arg.n_vifs);
5141 
5142 	kfree(arg.vifs);
5143 }
5144 
5145 static void ath11k_mac_op_change_chanctx(struct ieee80211_hw *hw,
5146 					 struct ieee80211_chanctx_conf *ctx,
5147 					 u32 changed)
5148 {
5149 	struct ath11k *ar = hw->priv;
5150 	struct ath11k_base *ab = ar->ab;
5151 
5152 	mutex_lock(&ar->conf_mutex);
5153 
5154 	ath11k_dbg(ab, ATH11K_DBG_MAC,
5155 		   "mac chanctx change freq %hu width %d ptr %pK changed %x\n",
5156 		   ctx->def.chan->center_freq, ctx->def.width, ctx, changed);
5157 
5158 	/* This shouldn't really happen because channel switching should use
5159 	 * switch_vif_chanctx().
5160 	 */
5161 	if (WARN_ON(changed & IEEE80211_CHANCTX_CHANGE_CHANNEL))
5162 		goto unlock;
5163 
5164 	if (changed & IEEE80211_CHANCTX_CHANGE_WIDTH)
5165 		ath11k_mac_update_active_vif_chan(ar, ctx);
5166 
5167 	/* TODO: Recalc radar detection */
5168 
5169 unlock:
5170 	mutex_unlock(&ar->conf_mutex);
5171 }
5172 
5173 static int ath11k_start_vdev_delay(struct ieee80211_hw *hw,
5174 				   struct ieee80211_vif *vif)
5175 {
5176 	struct ath11k *ar = hw->priv;
5177 	struct ath11k_base *ab = ar->ab;
5178 	struct ath11k_vif *arvif = (void *)vif->drv_priv;
5179 	int ret;
5180 
5181 	if (WARN_ON(arvif->is_started))
5182 		return -EBUSY;
5183 
5184 	ret = ath11k_mac_vdev_start(arvif, &arvif->chanctx.def);
5185 	if (ret) {
5186 		ath11k_warn(ab, "failed to start vdev %i addr %pM on freq %d: %d\n",
5187 			    arvif->vdev_id, vif->addr,
5188 			    arvif->chanctx.def.chan->center_freq, ret);
5189 		return ret;
5190 	}
5191 
5192 	if (arvif->vdev_type == WMI_VDEV_TYPE_MONITOR) {
5193 		ret = ath11k_monitor_vdev_up(ar, arvif->vdev_id);
5194 		if (ret) {
5195 			ath11k_warn(ab, "failed put monitor up: %d\n", ret);
5196 			return ret;
5197 		}
5198 	}
5199 
5200 	arvif->is_started = true;
5201 
5202 	/* TODO: Setup ps and cts/rts protection */
5203 	return 0;
5204 }
5205 
5206 static int
5207 ath11k_mac_op_assign_vif_chanctx(struct ieee80211_hw *hw,
5208 				 struct ieee80211_vif *vif,
5209 				 struct ieee80211_chanctx_conf *ctx)
5210 {
5211 	struct ath11k *ar = hw->priv;
5212 	struct ath11k_base *ab = ar->ab;
5213 	struct ath11k_vif *arvif = (void *)vif->drv_priv;
5214 	int ret;
5215 	struct peer_create_params param;
5216 
5217 	mutex_lock(&ar->conf_mutex);
5218 
5219 	ath11k_dbg(ab, ATH11K_DBG_MAC,
5220 		   "mac chanctx assign ptr %pK vdev_id %i\n",
5221 		   ctx, arvif->vdev_id);
5222 
5223 	/* for QCA6390 bss peer must be created before vdev_start */
5224 	if (ab->hw_params.vdev_start_delay &&
5225 	    arvif->vdev_type != WMI_VDEV_TYPE_AP &&
5226 	    arvif->vdev_type != WMI_VDEV_TYPE_MONITOR) {
5227 		memcpy(&arvif->chanctx, ctx, sizeof(*ctx));
5228 		mutex_unlock(&ar->conf_mutex);
5229 		return 0;
5230 	}
5231 
5232 	if (WARN_ON(arvif->is_started)) {
5233 		mutex_unlock(&ar->conf_mutex);
5234 		return -EBUSY;
5235 	}
5236 
5237 	if (ab->hw_params.vdev_start_delay) {
5238 		param.vdev_id = arvif->vdev_id;
5239 		param.peer_type = WMI_PEER_TYPE_DEFAULT;
5240 		param.peer_addr = ar->mac_addr;
5241 		ret = ath11k_peer_create(ar, arvif, NULL, &param);
5242 	}
5243 
5244 	ret = ath11k_mac_vdev_start(arvif, &ctx->def);
5245 	if (ret) {
5246 		ath11k_warn(ab, "failed to start vdev %i addr %pM on freq %d: %d\n",
5247 			    arvif->vdev_id, vif->addr,
5248 			    ctx->def.chan->center_freq, ret);
5249 		goto err;
5250 	}
5251 	if (arvif->vdev_type == WMI_VDEV_TYPE_MONITOR) {
5252 		ret = ath11k_monitor_vdev_up(ar, arvif->vdev_id);
5253 		if (ret)
5254 			goto err;
5255 	}
5256 
5257 	arvif->is_started = true;
5258 
5259 	/* TODO: Setup ps and cts/rts protection */
5260 
5261 	mutex_unlock(&ar->conf_mutex);
5262 
5263 	return 0;
5264 
5265 err:
5266 	mutex_unlock(&ar->conf_mutex);
5267 
5268 	return ret;
5269 }
5270 
5271 static void
5272 ath11k_mac_op_unassign_vif_chanctx(struct ieee80211_hw *hw,
5273 				   struct ieee80211_vif *vif,
5274 				   struct ieee80211_chanctx_conf *ctx)
5275 {
5276 	struct ath11k *ar = hw->priv;
5277 	struct ath11k_base *ab = ar->ab;
5278 	struct ath11k_vif *arvif = (void *)vif->drv_priv;
5279 	int ret;
5280 
5281 	mutex_lock(&ar->conf_mutex);
5282 
5283 	ath11k_dbg(ab, ATH11K_DBG_MAC,
5284 		   "mac chanctx unassign ptr %pK vdev_id %i\n",
5285 		   ctx, arvif->vdev_id);
5286 
5287 	WARN_ON(!arvif->is_started);
5288 
5289 	if (ab->hw_params.vdev_start_delay &&
5290 	    arvif->vdev_type == WMI_VDEV_TYPE_MONITOR &&
5291 	    ath11k_peer_find_by_addr(ab, ar->mac_addr))
5292 		ath11k_peer_delete(ar, arvif->vdev_id, ar->mac_addr);
5293 
5294 	ret = ath11k_mac_vdev_stop(arvif);
5295 	if (ret)
5296 		ath11k_warn(ab, "failed to stop vdev %i: %d\n",
5297 			    arvif->vdev_id, ret);
5298 
5299 	arvif->is_started = false;
5300 
5301 	if (ab->hw_params.vdev_start_delay &&
5302 	    arvif->vdev_type == WMI_VDEV_TYPE_MONITOR)
5303 		ath11k_wmi_vdev_down(ar, arvif->vdev_id);
5304 
5305 	mutex_unlock(&ar->conf_mutex);
5306 }
5307 
5308 static int
5309 ath11k_mac_op_switch_vif_chanctx(struct ieee80211_hw *hw,
5310 				 struct ieee80211_vif_chanctx_switch *vifs,
5311 				 int n_vifs,
5312 				 enum ieee80211_chanctx_switch_mode mode)
5313 {
5314 	struct ath11k *ar = hw->priv;
5315 
5316 	mutex_lock(&ar->conf_mutex);
5317 
5318 	ath11k_dbg(ar->ab, ATH11K_DBG_MAC,
5319 		   "mac chanctx switch n_vifs %d mode %d\n",
5320 		   n_vifs, mode);
5321 	ath11k_mac_update_vif_chan(ar, vifs, n_vifs);
5322 
5323 	mutex_unlock(&ar->conf_mutex);
5324 
5325 	return 0;
5326 }
5327 
5328 static int
5329 ath11k_set_vdev_param_to_all_vifs(struct ath11k *ar, int param, u32 value)
5330 {
5331 	struct ath11k_vif *arvif;
5332 	int ret = 0;
5333 
5334 	mutex_lock(&ar->conf_mutex);
5335 	list_for_each_entry(arvif, &ar->arvifs, list) {
5336 		ath11k_dbg(ar->ab, ATH11K_DBG_MAC, "setting mac vdev %d param %d value %d\n",
5337 			   param, arvif->vdev_id, value);
5338 
5339 		ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
5340 						    param, value);
5341 		if (ret) {
5342 			ath11k_warn(ar->ab, "failed to set param %d for vdev %d: %d\n",
5343 				    param, arvif->vdev_id, ret);
5344 			break;
5345 		}
5346 	}
5347 	mutex_unlock(&ar->conf_mutex);
5348 	return ret;
5349 }
5350 
5351 /* mac80211 stores device specific RTS/Fragmentation threshold value,
5352  * this is set interface specific to firmware from ath11k driver
5353  */
5354 static int ath11k_mac_op_set_rts_threshold(struct ieee80211_hw *hw, u32 value)
5355 {
5356 	struct ath11k *ar = hw->priv;
5357 	int param_id = WMI_VDEV_PARAM_RTS_THRESHOLD;
5358 
5359 	return ath11k_set_vdev_param_to_all_vifs(ar, param_id, value);
5360 }
5361 
5362 static int ath11k_mac_op_set_frag_threshold(struct ieee80211_hw *hw, u32 value)
5363 {
5364 	/* Even though there's a WMI vdev param for fragmentation threshold no
5365 	 * known firmware actually implements it. Moreover it is not possible to
5366 	 * rely frame fragmentation to mac80211 because firmware clears the
5367 	 * "more fragments" bit in frame control making it impossible for remote
5368 	 * devices to reassemble frames.
5369 	 *
5370 	 * Hence implement a dummy callback just to say fragmentation isn't
5371 	 * supported. This effectively prevents mac80211 from doing frame
5372 	 * fragmentation in software.
5373 	 */
5374 	return -EOPNOTSUPP;
5375 }
5376 
5377 static void ath11k_mac_op_flush(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
5378 				u32 queues, bool drop)
5379 {
5380 	struct ath11k *ar = hw->priv;
5381 	long time_left;
5382 
5383 	if (drop)
5384 		return;
5385 
5386 	time_left = wait_event_timeout(ar->dp.tx_empty_waitq,
5387 				       (atomic_read(&ar->dp.num_tx_pending) == 0),
5388 				       ATH11K_FLUSH_TIMEOUT);
5389 	if (time_left == 0)
5390 		ath11k_warn(ar->ab, "failed to flush transmit queue %ld\n", time_left);
5391 }
5392 
5393 static int
5394 ath11k_mac_bitrate_mask_num_ht_rates(struct ath11k *ar,
5395 				     enum nl80211_band band,
5396 				     const struct cfg80211_bitrate_mask *mask)
5397 {
5398 	int num_rates = 0;
5399 	int i;
5400 
5401 	for (i = 0; i < ARRAY_SIZE(mask->control[band].ht_mcs); i++)
5402 		num_rates += hweight16(mask->control[band].ht_mcs[i]);
5403 
5404 	return num_rates;
5405 }
5406 
5407 static bool
5408 ath11k_mac_has_single_legacy_rate(struct ath11k *ar,
5409 				  enum nl80211_band band,
5410 				  const struct cfg80211_bitrate_mask *mask)
5411 {
5412 	int num_rates = 0;
5413 
5414 	num_rates = hweight32(mask->control[band].legacy);
5415 
5416 	if (ath11k_mac_bitrate_mask_num_ht_rates(ar, band, mask))
5417 		return false;
5418 
5419 	if (ath11k_mac_bitrate_mask_num_vht_rates(ar, band, mask))
5420 		return false;
5421 
5422 	return num_rates == 1;
5423 }
5424 
5425 static bool
5426 ath11k_mac_bitrate_mask_get_single_nss(struct ath11k *ar,
5427 				       enum nl80211_band band,
5428 				       const struct cfg80211_bitrate_mask *mask,
5429 				       int *nss)
5430 {
5431 	struct ieee80211_supported_band *sband = &ar->mac.sbands[band];
5432 	u16 vht_mcs_map = le16_to_cpu(sband->vht_cap.vht_mcs.tx_mcs_map);
5433 	u8 ht_nss_mask = 0;
5434 	u8 vht_nss_mask = 0;
5435 	int i;
5436 
5437 	/* No need to consider legacy here. Basic rates are always present
5438 	 * in bitrate mask
5439 	 */
5440 
5441 	for (i = 0; i < ARRAY_SIZE(mask->control[band].ht_mcs); i++) {
5442 		if (mask->control[band].ht_mcs[i] == 0)
5443 			continue;
5444 		else if (mask->control[band].ht_mcs[i] ==
5445 			 sband->ht_cap.mcs.rx_mask[i])
5446 			ht_nss_mask |= BIT(i);
5447 		else
5448 			return false;
5449 	}
5450 
5451 	for (i = 0; i < ARRAY_SIZE(mask->control[band].vht_mcs); i++) {
5452 		if (mask->control[band].vht_mcs[i] == 0)
5453 			continue;
5454 		else if (mask->control[band].vht_mcs[i] ==
5455 			 ath11k_mac_get_max_vht_mcs_map(vht_mcs_map, i))
5456 			vht_nss_mask |= BIT(i);
5457 		else
5458 			return false;
5459 	}
5460 
5461 	if (ht_nss_mask != vht_nss_mask)
5462 		return false;
5463 
5464 	if (ht_nss_mask == 0)
5465 		return false;
5466 
5467 	if (BIT(fls(ht_nss_mask)) - 1 != ht_nss_mask)
5468 		return false;
5469 
5470 	*nss = fls(ht_nss_mask);
5471 
5472 	return true;
5473 }
5474 
5475 static int
5476 ath11k_mac_get_single_legacy_rate(struct ath11k *ar,
5477 				  enum nl80211_band band,
5478 				  const struct cfg80211_bitrate_mask *mask,
5479 				  u32 *rate, u8 *nss)
5480 {
5481 	int rate_idx;
5482 	u16 bitrate;
5483 	u8 preamble;
5484 	u8 hw_rate;
5485 
5486 	if (hweight32(mask->control[band].legacy) != 1)
5487 		return -EINVAL;
5488 
5489 	rate_idx = ffs(mask->control[band].legacy) - 1;
5490 
5491 	if (band == NL80211_BAND_5GHZ || band == NL80211_BAND_6GHZ)
5492 		rate_idx += ATH11K_MAC_FIRST_OFDM_RATE_IDX;
5493 
5494 	hw_rate = ath11k_legacy_rates[rate_idx].hw_value;
5495 	bitrate = ath11k_legacy_rates[rate_idx].bitrate;
5496 
5497 	if (ath11k_mac_bitrate_is_cck(bitrate))
5498 		preamble = WMI_RATE_PREAMBLE_CCK;
5499 	else
5500 		preamble = WMI_RATE_PREAMBLE_OFDM;
5501 
5502 	*nss = 1;
5503 	*rate = ATH11K_HW_RATE_CODE(hw_rate, 0, preamble);
5504 
5505 	return 0;
5506 }
5507 
5508 static int ath11k_mac_set_fixed_rate_params(struct ath11k_vif *arvif,
5509 					    u32 rate, u8 nss, u8 sgi, u8 ldpc)
5510 {
5511 	struct ath11k *ar = arvif->ar;
5512 	u32 vdev_param;
5513 	int ret;
5514 
5515 	lockdep_assert_held(&ar->conf_mutex);
5516 
5517 	ath11k_dbg(ar->ab, ATH11K_DBG_MAC, "mac set fixed rate params vdev %i rate 0x%02hhx nss %hhu sgi %hhu\n",
5518 		   arvif->vdev_id, rate, nss, sgi);
5519 
5520 	vdev_param = WMI_VDEV_PARAM_FIXED_RATE;
5521 	ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
5522 					    vdev_param, rate);
5523 	if (ret) {
5524 		ath11k_warn(ar->ab, "failed to set fixed rate param 0x%02x: %d\n",
5525 			    rate, ret);
5526 		return ret;
5527 	}
5528 
5529 	vdev_param = WMI_VDEV_PARAM_NSS;
5530 	ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
5531 					    vdev_param, nss);
5532 	if (ret) {
5533 		ath11k_warn(ar->ab, "failed to set nss param %d: %d\n",
5534 			    nss, ret);
5535 		return ret;
5536 	}
5537 
5538 	vdev_param = WMI_VDEV_PARAM_SGI;
5539 	ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
5540 					    vdev_param, sgi);
5541 	if (ret) {
5542 		ath11k_warn(ar->ab, "failed to set sgi param %d: %d\n",
5543 			    sgi, ret);
5544 		return ret;
5545 	}
5546 
5547 	vdev_param = WMI_VDEV_PARAM_LDPC;
5548 	ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
5549 					    vdev_param, ldpc);
5550 	if (ret) {
5551 		ath11k_warn(ar->ab, "failed to set ldpc param %d: %d\n",
5552 			    ldpc, ret);
5553 		return ret;
5554 	}
5555 
5556 	return 0;
5557 }
5558 
5559 static bool
5560 ath11k_mac_vht_mcs_range_present(struct ath11k *ar,
5561 				 enum nl80211_band band,
5562 				 const struct cfg80211_bitrate_mask *mask)
5563 {
5564 	int i;
5565 	u16 vht_mcs;
5566 
5567 	for (i = 0; i < NL80211_VHT_NSS_MAX; i++) {
5568 		vht_mcs = mask->control[band].vht_mcs[i];
5569 
5570 		switch (vht_mcs) {
5571 		case 0:
5572 		case BIT(8) - 1:
5573 		case BIT(9) - 1:
5574 		case BIT(10) - 1:
5575 			break;
5576 		default:
5577 			return false;
5578 		}
5579 	}
5580 
5581 	return true;
5582 }
5583 
5584 static void ath11k_mac_set_bitrate_mask_iter(void *data,
5585 					     struct ieee80211_sta *sta)
5586 {
5587 	struct ath11k_vif *arvif = data;
5588 	struct ath11k_sta *arsta = (struct ath11k_sta *)sta->drv_priv;
5589 	struct ath11k *ar = arvif->ar;
5590 
5591 	spin_lock_bh(&ar->data_lock);
5592 	arsta->changed |= IEEE80211_RC_SUPP_RATES_CHANGED;
5593 	spin_unlock_bh(&ar->data_lock);
5594 
5595 	ieee80211_queue_work(ar->hw, &arsta->update_wk);
5596 }
5597 
5598 static void ath11k_mac_disable_peer_fixed_rate(void *data,
5599 					       struct ieee80211_sta *sta)
5600 {
5601 	struct ath11k_vif *arvif = data;
5602 	struct ath11k *ar = arvif->ar;
5603 	int ret;
5604 
5605 	ret = ath11k_wmi_set_peer_param(ar, sta->addr,
5606 					arvif->vdev_id,
5607 					WMI_PEER_PARAM_FIXED_RATE,
5608 					WMI_FIXED_RATE_NONE);
5609 	if (ret)
5610 		ath11k_warn(ar->ab,
5611 			    "failed to disable peer fixed rate for STA %pM ret %d\n",
5612 			    sta->addr, ret);
5613 }
5614 
5615 static int
5616 ath11k_mac_op_set_bitrate_mask(struct ieee80211_hw *hw,
5617 			       struct ieee80211_vif *vif,
5618 			       const struct cfg80211_bitrate_mask *mask)
5619 {
5620 	struct ath11k_vif *arvif = (void *)vif->drv_priv;
5621 	struct cfg80211_chan_def def;
5622 	struct ath11k *ar = arvif->ar;
5623 	enum nl80211_band band;
5624 	const u8 *ht_mcs_mask;
5625 	const u16 *vht_mcs_mask;
5626 	u32 rate;
5627 	u8 nss;
5628 	u8 sgi;
5629 	u8 ldpc;
5630 	int single_nss;
5631 	int ret;
5632 	int num_rates;
5633 
5634 	if (ath11k_mac_vif_chan(vif, &def))
5635 		return -EPERM;
5636 
5637 	band = def.chan->band;
5638 	ht_mcs_mask = mask->control[band].ht_mcs;
5639 	vht_mcs_mask = mask->control[band].vht_mcs;
5640 	ldpc = !!(ar->ht_cap_info & WMI_HT_CAP_LDPC);
5641 
5642 	sgi = mask->control[band].gi;
5643 	if (sgi == NL80211_TXRATE_FORCE_LGI)
5644 		return -EINVAL;
5645 
5646 	/* mac80211 doesn't support sending a fixed HT/VHT MCS alone, rather it
5647 	 * requires passing atleast one of used basic rates along with them.
5648 	 * Fixed rate setting across different preambles(legacy, HT, VHT) is
5649 	 * not supported by the FW. Hence use of FIXED_RATE vdev param is not
5650 	 * suitable for setting single HT/VHT rates.
5651 	 * But, there could be a single basic rate passed from userspace which
5652 	 * can be done through the FIXED_RATE param.
5653 	 */
5654 	if (ath11k_mac_has_single_legacy_rate(ar, band, mask)) {
5655 		ret = ath11k_mac_get_single_legacy_rate(ar, band, mask, &rate,
5656 							&nss);
5657 		if (ret) {
5658 			ath11k_warn(ar->ab, "failed to get single legacy rate for vdev %i: %d\n",
5659 				    arvif->vdev_id, ret);
5660 			return ret;
5661 		}
5662 		ieee80211_iterate_stations_atomic(ar->hw,
5663 						  ath11k_mac_disable_peer_fixed_rate,
5664 						  arvif);
5665 	} else if (ath11k_mac_bitrate_mask_get_single_nss(ar, band, mask,
5666 							  &single_nss)) {
5667 		rate = WMI_FIXED_RATE_NONE;
5668 		nss = single_nss;
5669 	} else {
5670 		rate = WMI_FIXED_RATE_NONE;
5671 		nss = min_t(u32, ar->num_tx_chains,
5672 			    max(ath11k_mac_max_ht_nss(ht_mcs_mask),
5673 				ath11k_mac_max_vht_nss(vht_mcs_mask)));
5674 
5675 		/* If multiple rates across different preambles are given
5676 		 * we can reconfigure this info with all peers using PEER_ASSOC
5677 		 * command with the below exception cases.
5678 		 * - Single VHT Rate : peer_assoc command accommodates only MCS
5679 		 * range values i.e 0-7, 0-8, 0-9 for VHT. Though mac80211
5680 		 * mandates passing basic rates along with HT/VHT rates, FW
5681 		 * doesn't allow switching from VHT to Legacy. Hence instead of
5682 		 * setting legacy and VHT rates using RATEMASK_CMD vdev cmd,
5683 		 * we could set this VHT rate as peer fixed rate param, which
5684 		 * will override FIXED rate and FW rate control algorithm.
5685 		 * If single VHT rate is passed along with HT rates, we select
5686 		 * the VHT rate as fixed rate for vht peers.
5687 		 * - Multiple VHT Rates : When Multiple VHT rates are given,this
5688 		 * can be set using RATEMASK CMD which uses FW rate-ctl alg.
5689 		 * TODO: Setting multiple VHT MCS and replacing peer_assoc with
5690 		 * RATEMASK_CMDID can cover all use cases of setting rates
5691 		 * across multiple preambles and rates within same type.
5692 		 * But requires more validation of the command at this point.
5693 		 */
5694 
5695 		num_rates = ath11k_mac_bitrate_mask_num_vht_rates(ar, band,
5696 								  mask);
5697 
5698 		if (!ath11k_mac_vht_mcs_range_present(ar, band, mask) &&
5699 		    num_rates > 1) {
5700 			/* TODO: Handle multiple VHT MCS values setting using
5701 			 * RATEMASK CMD
5702 			 */
5703 			ath11k_warn(ar->ab,
5704 				    "Setting more than one MCS Value in bitrate mask not supported\n");
5705 			return -EINVAL;
5706 		}
5707 
5708 		ieee80211_iterate_stations_atomic(ar->hw,
5709 						  ath11k_mac_disable_peer_fixed_rate,
5710 						  arvif);
5711 
5712 		mutex_lock(&ar->conf_mutex);
5713 
5714 		arvif->bitrate_mask = *mask;
5715 		ieee80211_iterate_stations_atomic(ar->hw,
5716 						  ath11k_mac_set_bitrate_mask_iter,
5717 						  arvif);
5718 
5719 		mutex_unlock(&ar->conf_mutex);
5720 	}
5721 
5722 	mutex_lock(&ar->conf_mutex);
5723 
5724 	ret = ath11k_mac_set_fixed_rate_params(arvif, rate, nss, sgi, ldpc);
5725 	if (ret) {
5726 		ath11k_warn(ar->ab, "failed to set fixed rate params on vdev %i: %d\n",
5727 			    arvif->vdev_id, ret);
5728 	}
5729 
5730 	mutex_unlock(&ar->conf_mutex);
5731 
5732 	return ret;
5733 }
5734 
5735 static void
5736 ath11k_mac_op_reconfig_complete(struct ieee80211_hw *hw,
5737 				enum ieee80211_reconfig_type reconfig_type)
5738 {
5739 	struct ath11k *ar = hw->priv;
5740 
5741 	if (reconfig_type != IEEE80211_RECONFIG_TYPE_RESTART)
5742 		return;
5743 
5744 	mutex_lock(&ar->conf_mutex);
5745 
5746 	if (ar->state == ATH11K_STATE_RESTARTED) {
5747 		ath11k_warn(ar->ab, "pdev %d successfully recovered\n",
5748 			    ar->pdev->pdev_id);
5749 		ar->state = ATH11K_STATE_ON;
5750 		ieee80211_wake_queues(ar->hw);
5751 	}
5752 
5753 	mutex_unlock(&ar->conf_mutex);
5754 }
5755 
5756 static void
5757 ath11k_mac_update_bss_chan_survey(struct ath11k *ar,
5758 				  struct ieee80211_channel *channel)
5759 {
5760 	int ret;
5761 	enum wmi_bss_chan_info_req_type type = WMI_BSS_SURVEY_REQ_TYPE_READ;
5762 
5763 	lockdep_assert_held(&ar->conf_mutex);
5764 
5765 	if (!test_bit(WMI_TLV_SERVICE_BSS_CHANNEL_INFO_64, ar->ab->wmi_ab.svc_map) ||
5766 	    ar->rx_channel != channel)
5767 		return;
5768 
5769 	if (ar->scan.state != ATH11K_SCAN_IDLE) {
5770 		ath11k_dbg(ar->ab, ATH11K_DBG_MAC,
5771 			   "ignoring bss chan info req while scanning..\n");
5772 		return;
5773 	}
5774 
5775 	reinit_completion(&ar->bss_survey_done);
5776 
5777 	ret = ath11k_wmi_pdev_bss_chan_info_request(ar, type);
5778 	if (ret) {
5779 		ath11k_warn(ar->ab, "failed to send pdev bss chan info request\n");
5780 		return;
5781 	}
5782 
5783 	ret = wait_for_completion_timeout(&ar->bss_survey_done, 3 * HZ);
5784 	if (ret == 0)
5785 		ath11k_warn(ar->ab, "bss channel survey timed out\n");
5786 }
5787 
5788 static int ath11k_mac_op_get_survey(struct ieee80211_hw *hw, int idx,
5789 				    struct survey_info *survey)
5790 {
5791 	struct ath11k *ar = hw->priv;
5792 	struct ieee80211_supported_band *sband;
5793 	struct survey_info *ar_survey;
5794 	int ret = 0;
5795 
5796 	if (idx >= ATH11K_NUM_CHANS)
5797 		return -ENOENT;
5798 
5799 	ar_survey = &ar->survey[idx];
5800 
5801 	mutex_lock(&ar->conf_mutex);
5802 
5803 	sband = hw->wiphy->bands[NL80211_BAND_2GHZ];
5804 	if (sband && idx >= sband->n_channels) {
5805 		idx -= sband->n_channels;
5806 		sband = NULL;
5807 	}
5808 
5809 	if (!sband)
5810 		sband = hw->wiphy->bands[NL80211_BAND_5GHZ];
5811 
5812 	if (!sband || idx >= sband->n_channels) {
5813 		ret = -ENOENT;
5814 		goto exit;
5815 	}
5816 
5817 	ath11k_mac_update_bss_chan_survey(ar, &sband->channels[idx]);
5818 
5819 	spin_lock_bh(&ar->data_lock);
5820 	memcpy(survey, ar_survey, sizeof(*survey));
5821 	spin_unlock_bh(&ar->data_lock);
5822 
5823 	survey->channel = &sband->channels[idx];
5824 
5825 	if (ar->rx_channel == survey->channel)
5826 		survey->filled |= SURVEY_INFO_IN_USE;
5827 
5828 exit:
5829 	mutex_unlock(&ar->conf_mutex);
5830 	return ret;
5831 }
5832 
5833 static void ath11k_mac_op_sta_statistics(struct ieee80211_hw *hw,
5834 					 struct ieee80211_vif *vif,
5835 					 struct ieee80211_sta *sta,
5836 					 struct station_info *sinfo)
5837 {
5838 	struct ath11k_sta *arsta = (struct ath11k_sta *)sta->drv_priv;
5839 
5840 	sinfo->rx_duration = arsta->rx_duration;
5841 	sinfo->filled |= BIT_ULL(NL80211_STA_INFO_RX_DURATION);
5842 
5843 	sinfo->tx_duration = arsta->tx_duration;
5844 	sinfo->filled |= BIT_ULL(NL80211_STA_INFO_TX_DURATION);
5845 
5846 	if (!arsta->txrate.legacy && !arsta->txrate.nss)
5847 		return;
5848 
5849 	if (arsta->txrate.legacy) {
5850 		sinfo->txrate.legacy = arsta->txrate.legacy;
5851 	} else {
5852 		sinfo->txrate.mcs = arsta->txrate.mcs;
5853 		sinfo->txrate.nss = arsta->txrate.nss;
5854 		sinfo->txrate.bw = arsta->txrate.bw;
5855 		sinfo->txrate.he_gi = arsta->txrate.he_gi;
5856 		sinfo->txrate.he_dcm = arsta->txrate.he_dcm;
5857 		sinfo->txrate.he_ru_alloc = arsta->txrate.he_ru_alloc;
5858 	}
5859 	sinfo->txrate.flags = arsta->txrate.flags;
5860 	sinfo->filled |= BIT_ULL(NL80211_STA_INFO_TX_BITRATE);
5861 
5862 	/* TODO: Use real NF instead of default one. */
5863 	sinfo->signal = arsta->rssi_comb + ATH11K_DEFAULT_NOISE_FLOOR;
5864 }
5865 
5866 static const struct ieee80211_ops ath11k_ops = {
5867 	.tx				= ath11k_mac_op_tx,
5868 	.start                          = ath11k_mac_op_start,
5869 	.stop                           = ath11k_mac_op_stop,
5870 	.reconfig_complete              = ath11k_mac_op_reconfig_complete,
5871 	.add_interface                  = ath11k_mac_op_add_interface,
5872 	.remove_interface		= ath11k_mac_op_remove_interface,
5873 	.update_vif_offload		= ath11k_mac_op_update_vif_offload,
5874 	.config                         = ath11k_mac_op_config,
5875 	.bss_info_changed               = ath11k_mac_op_bss_info_changed,
5876 	.configure_filter		= ath11k_mac_op_configure_filter,
5877 	.hw_scan                        = ath11k_mac_op_hw_scan,
5878 	.cancel_hw_scan                 = ath11k_mac_op_cancel_hw_scan,
5879 	.set_key                        = ath11k_mac_op_set_key,
5880 	.sta_state                      = ath11k_mac_op_sta_state,
5881 	.sta_set_txpwr			= ath11k_mac_op_sta_set_txpwr,
5882 	.sta_rc_update			= ath11k_mac_op_sta_rc_update,
5883 	.conf_tx                        = ath11k_mac_op_conf_tx,
5884 	.set_antenna			= ath11k_mac_op_set_antenna,
5885 	.get_antenna			= ath11k_mac_op_get_antenna,
5886 	.ampdu_action			= ath11k_mac_op_ampdu_action,
5887 	.add_chanctx			= ath11k_mac_op_add_chanctx,
5888 	.remove_chanctx			= ath11k_mac_op_remove_chanctx,
5889 	.change_chanctx			= ath11k_mac_op_change_chanctx,
5890 	.assign_vif_chanctx		= ath11k_mac_op_assign_vif_chanctx,
5891 	.unassign_vif_chanctx		= ath11k_mac_op_unassign_vif_chanctx,
5892 	.switch_vif_chanctx		= ath11k_mac_op_switch_vif_chanctx,
5893 	.set_rts_threshold		= ath11k_mac_op_set_rts_threshold,
5894 	.set_frag_threshold		= ath11k_mac_op_set_frag_threshold,
5895 	.set_bitrate_mask		= ath11k_mac_op_set_bitrate_mask,
5896 	.get_survey			= ath11k_mac_op_get_survey,
5897 	.flush				= ath11k_mac_op_flush,
5898 	.sta_statistics			= ath11k_mac_op_sta_statistics,
5899 	CFG80211_TESTMODE_CMD(ath11k_tm_cmd)
5900 #ifdef CONFIG_ATH11K_DEBUGFS
5901 	.sta_add_debugfs		= ath11k_debugfs_sta_op_add,
5902 #endif
5903 };
5904 
5905 static void ath11k_mac_update_ch_list(struct ath11k *ar,
5906 				      struct ieee80211_supported_band *band,
5907 				      u32 freq_low, u32 freq_high)
5908 {
5909 	int i;
5910 
5911 	if (!(freq_low && freq_high))
5912 		return;
5913 
5914 	for (i = 0; i < band->n_channels; i++) {
5915 		if (band->channels[i].center_freq < freq_low ||
5916 		    band->channels[i].center_freq > freq_high)
5917 			band->channels[i].flags |= IEEE80211_CHAN_DISABLED;
5918 	}
5919 }
5920 
5921 static u32 ath11k_get_phy_id(struct ath11k *ar, u32 band)
5922 {
5923 	struct ath11k_pdev *pdev = ar->pdev;
5924 	struct ath11k_pdev_cap *pdev_cap = &pdev->cap;
5925 
5926 	if (band == WMI_HOST_WLAN_2G_CAP)
5927 		return pdev_cap->band[NL80211_BAND_2GHZ].phy_id;
5928 
5929 	if (band == WMI_HOST_WLAN_5G_CAP)
5930 		return pdev_cap->band[NL80211_BAND_5GHZ].phy_id;
5931 
5932 	ath11k_warn(ar->ab, "unsupported phy cap:%d\n", band);
5933 
5934 	return 0;
5935 }
5936 
5937 static int ath11k_mac_setup_channels_rates(struct ath11k *ar,
5938 					   u32 supported_bands)
5939 {
5940 	struct ieee80211_supported_band *band;
5941 	struct ath11k_hal_reg_capabilities_ext *reg_cap;
5942 	void *channels;
5943 	u32 phy_id;
5944 
5945 	BUILD_BUG_ON((ARRAY_SIZE(ath11k_2ghz_channels) +
5946 		      ARRAY_SIZE(ath11k_5ghz_channels) +
5947 		      ARRAY_SIZE(ath11k_6ghz_channels)) !=
5948 		     ATH11K_NUM_CHANS);
5949 
5950 	reg_cap = &ar->ab->hal_reg_cap[ar->pdev_idx];
5951 
5952 	if (supported_bands & WMI_HOST_WLAN_2G_CAP) {
5953 		channels = kmemdup(ath11k_2ghz_channels,
5954 				   sizeof(ath11k_2ghz_channels),
5955 				   GFP_KERNEL);
5956 		if (!channels)
5957 			return -ENOMEM;
5958 
5959 		band = &ar->mac.sbands[NL80211_BAND_2GHZ];
5960 		band->band = NL80211_BAND_2GHZ;
5961 		band->n_channels = ARRAY_SIZE(ath11k_2ghz_channels);
5962 		band->channels = channels;
5963 		band->n_bitrates = ath11k_g_rates_size;
5964 		band->bitrates = ath11k_g_rates;
5965 		ar->hw->wiphy->bands[NL80211_BAND_2GHZ] = band;
5966 
5967 		if (ar->ab->hw_params.single_pdev_only) {
5968 			phy_id = ath11k_get_phy_id(ar, WMI_HOST_WLAN_2G_CAP);
5969 			reg_cap = &ar->ab->hal_reg_cap[phy_id];
5970 		}
5971 		ath11k_mac_update_ch_list(ar, band,
5972 					  reg_cap->low_2ghz_chan,
5973 					  reg_cap->high_2ghz_chan);
5974 	}
5975 
5976 	if (supported_bands & WMI_HOST_WLAN_5G_CAP) {
5977 		if (reg_cap->high_5ghz_chan >= ATH11K_MAX_6G_FREQ) {
5978 			channels = kmemdup(ath11k_6ghz_channels,
5979 					   sizeof(ath11k_6ghz_channels), GFP_KERNEL);
5980 			if (!channels) {
5981 				kfree(ar->mac.sbands[NL80211_BAND_2GHZ].channels);
5982 				return -ENOMEM;
5983 			}
5984 
5985 			ar->supports_6ghz = true;
5986 			band = &ar->mac.sbands[NL80211_BAND_6GHZ];
5987 			band->band = NL80211_BAND_6GHZ;
5988 			band->n_channels = ARRAY_SIZE(ath11k_6ghz_channels);
5989 			band->channels = channels;
5990 			band->n_bitrates = ath11k_a_rates_size;
5991 			band->bitrates = ath11k_a_rates;
5992 			ar->hw->wiphy->bands[NL80211_BAND_6GHZ] = band;
5993 			ath11k_mac_update_ch_list(ar, band,
5994 						  reg_cap->low_5ghz_chan,
5995 						  reg_cap->high_5ghz_chan);
5996 		}
5997 
5998 		if (reg_cap->low_5ghz_chan < ATH11K_MIN_6G_FREQ) {
5999 			channels = kmemdup(ath11k_5ghz_channels,
6000 					   sizeof(ath11k_5ghz_channels),
6001 					   GFP_KERNEL);
6002 			if (!channels) {
6003 				kfree(ar->mac.sbands[NL80211_BAND_2GHZ].channels);
6004 				kfree(ar->mac.sbands[NL80211_BAND_6GHZ].channels);
6005 				return -ENOMEM;
6006 			}
6007 
6008 			band = &ar->mac.sbands[NL80211_BAND_5GHZ];
6009 			band->band = NL80211_BAND_5GHZ;
6010 			band->n_channels = ARRAY_SIZE(ath11k_5ghz_channels);
6011 			band->channels = channels;
6012 			band->n_bitrates = ath11k_a_rates_size;
6013 			band->bitrates = ath11k_a_rates;
6014 			ar->hw->wiphy->bands[NL80211_BAND_5GHZ] = band;
6015 
6016 			if (ar->ab->hw_params.single_pdev_only) {
6017 				phy_id = ath11k_get_phy_id(ar, WMI_HOST_WLAN_5G_CAP);
6018 				reg_cap = &ar->ab->hal_reg_cap[phy_id];
6019 			}
6020 
6021 			ath11k_mac_update_ch_list(ar, band,
6022 						  reg_cap->low_5ghz_chan,
6023 						  reg_cap->high_5ghz_chan);
6024 		}
6025 	}
6026 
6027 	return 0;
6028 }
6029 
6030 static int ath11k_mac_setup_iface_combinations(struct ath11k *ar)
6031 {
6032 	struct ath11k_base *ab = ar->ab;
6033 	struct ieee80211_iface_combination *combinations;
6034 	struct ieee80211_iface_limit *limits;
6035 	int n_limits;
6036 
6037 	combinations = kzalloc(sizeof(*combinations), GFP_KERNEL);
6038 	if (!combinations)
6039 		return -ENOMEM;
6040 
6041 	n_limits = 2;
6042 
6043 	limits = kcalloc(n_limits, sizeof(*limits), GFP_KERNEL);
6044 	if (!limits) {
6045 		kfree(combinations);
6046 		return -ENOMEM;
6047 	}
6048 
6049 	limits[0].max = 1;
6050 	limits[0].types |= BIT(NL80211_IFTYPE_STATION);
6051 
6052 	limits[1].max = 16;
6053 	limits[1].types |= BIT(NL80211_IFTYPE_AP);
6054 
6055 	if (IS_ENABLED(CONFIG_MAC80211_MESH) &&
6056 	    ab->hw_params.interface_modes & BIT(NL80211_IFTYPE_MESH_POINT))
6057 		limits[1].types |= BIT(NL80211_IFTYPE_MESH_POINT);
6058 
6059 	combinations[0].limits = limits;
6060 	combinations[0].n_limits = n_limits;
6061 	combinations[0].max_interfaces = 16;
6062 	combinations[0].num_different_channels = 1;
6063 	combinations[0].beacon_int_infra_match = true;
6064 	combinations[0].beacon_int_min_gcd = 100;
6065 	combinations[0].radar_detect_widths = BIT(NL80211_CHAN_WIDTH_20_NOHT) |
6066 						BIT(NL80211_CHAN_WIDTH_20) |
6067 						BIT(NL80211_CHAN_WIDTH_40) |
6068 						BIT(NL80211_CHAN_WIDTH_80);
6069 
6070 	ar->hw->wiphy->iface_combinations = combinations;
6071 	ar->hw->wiphy->n_iface_combinations = 1;
6072 
6073 	return 0;
6074 }
6075 
6076 static const u8 ath11k_if_types_ext_capa[] = {
6077 	[0] = WLAN_EXT_CAPA1_EXT_CHANNEL_SWITCHING,
6078 	[7] = WLAN_EXT_CAPA8_OPMODE_NOTIF,
6079 };
6080 
6081 static const u8 ath11k_if_types_ext_capa_sta[] = {
6082 	[0] = WLAN_EXT_CAPA1_EXT_CHANNEL_SWITCHING,
6083 	[7] = WLAN_EXT_CAPA8_OPMODE_NOTIF,
6084 	[9] = WLAN_EXT_CAPA10_TWT_REQUESTER_SUPPORT,
6085 };
6086 
6087 static const u8 ath11k_if_types_ext_capa_ap[] = {
6088 	[0] = WLAN_EXT_CAPA1_EXT_CHANNEL_SWITCHING,
6089 	[7] = WLAN_EXT_CAPA8_OPMODE_NOTIF,
6090 	[9] = WLAN_EXT_CAPA10_TWT_RESPONDER_SUPPORT,
6091 };
6092 
6093 static const struct wiphy_iftype_ext_capab ath11k_iftypes_ext_capa[] = {
6094 	{
6095 		.extended_capabilities = ath11k_if_types_ext_capa,
6096 		.extended_capabilities_mask = ath11k_if_types_ext_capa,
6097 		.extended_capabilities_len = sizeof(ath11k_if_types_ext_capa),
6098 	}, {
6099 		.iftype = NL80211_IFTYPE_STATION,
6100 		.extended_capabilities = ath11k_if_types_ext_capa_sta,
6101 		.extended_capabilities_mask = ath11k_if_types_ext_capa_sta,
6102 		.extended_capabilities_len =
6103 				sizeof(ath11k_if_types_ext_capa_sta),
6104 	}, {
6105 		.iftype = NL80211_IFTYPE_AP,
6106 		.extended_capabilities = ath11k_if_types_ext_capa_ap,
6107 		.extended_capabilities_mask = ath11k_if_types_ext_capa_ap,
6108 		.extended_capabilities_len =
6109 				sizeof(ath11k_if_types_ext_capa_ap),
6110 	},
6111 };
6112 
6113 static void __ath11k_mac_unregister(struct ath11k *ar)
6114 {
6115 	cancel_work_sync(&ar->regd_update_work);
6116 
6117 	ieee80211_unregister_hw(ar->hw);
6118 
6119 	idr_for_each(&ar->txmgmt_idr, ath11k_mac_tx_mgmt_pending_free, ar);
6120 	idr_destroy(&ar->txmgmt_idr);
6121 
6122 	kfree(ar->mac.sbands[NL80211_BAND_2GHZ].channels);
6123 	kfree(ar->mac.sbands[NL80211_BAND_5GHZ].channels);
6124 	kfree(ar->mac.sbands[NL80211_BAND_6GHZ].channels);
6125 
6126 	kfree(ar->hw->wiphy->iface_combinations[0].limits);
6127 	kfree(ar->hw->wiphy->iface_combinations);
6128 
6129 	SET_IEEE80211_DEV(ar->hw, NULL);
6130 }
6131 
6132 void ath11k_mac_unregister(struct ath11k_base *ab)
6133 {
6134 	struct ath11k *ar;
6135 	struct ath11k_pdev *pdev;
6136 	int i;
6137 
6138 	for (i = 0; i < ab->num_radios; i++) {
6139 		pdev = &ab->pdevs[i];
6140 		ar = pdev->ar;
6141 		if (!ar)
6142 			continue;
6143 
6144 		__ath11k_mac_unregister(ar);
6145 	}
6146 }
6147 
6148 static int __ath11k_mac_register(struct ath11k *ar)
6149 {
6150 	struct ath11k_base *ab = ar->ab;
6151 	struct ath11k_pdev_cap *cap = &ar->pdev->cap;
6152 	static const u32 cipher_suites[] = {
6153 		WLAN_CIPHER_SUITE_TKIP,
6154 		WLAN_CIPHER_SUITE_CCMP,
6155 		WLAN_CIPHER_SUITE_AES_CMAC,
6156 		WLAN_CIPHER_SUITE_BIP_CMAC_256,
6157 		WLAN_CIPHER_SUITE_BIP_GMAC_128,
6158 		WLAN_CIPHER_SUITE_BIP_GMAC_256,
6159 		WLAN_CIPHER_SUITE_GCMP,
6160 		WLAN_CIPHER_SUITE_GCMP_256,
6161 		WLAN_CIPHER_SUITE_CCMP_256,
6162 	};
6163 	int ret;
6164 	u32 ht_cap = 0;
6165 
6166 	ath11k_pdev_caps_update(ar);
6167 
6168 	SET_IEEE80211_PERM_ADDR(ar->hw, ar->mac_addr);
6169 
6170 	SET_IEEE80211_DEV(ar->hw, ab->dev);
6171 
6172 	ret = ath11k_mac_setup_channels_rates(ar,
6173 					      cap->supported_bands);
6174 	if (ret)
6175 		goto err;
6176 
6177 	ath11k_mac_setup_ht_vht_cap(ar, cap, &ht_cap);
6178 	ath11k_mac_setup_he_cap(ar, cap);
6179 
6180 	ret = ath11k_mac_setup_iface_combinations(ar);
6181 	if (ret) {
6182 		ath11k_err(ar->ab, "failed to setup interface combinations: %d\n", ret);
6183 		goto err_free_channels;
6184 	}
6185 
6186 	ar->hw->wiphy->available_antennas_rx = cap->rx_chain_mask;
6187 	ar->hw->wiphy->available_antennas_tx = cap->tx_chain_mask;
6188 
6189 	ar->hw->wiphy->interface_modes = ab->hw_params.interface_modes;
6190 
6191 	ieee80211_hw_set(ar->hw, SIGNAL_DBM);
6192 	ieee80211_hw_set(ar->hw, SUPPORTS_PS);
6193 	ieee80211_hw_set(ar->hw, SUPPORTS_DYNAMIC_PS);
6194 	ieee80211_hw_set(ar->hw, MFP_CAPABLE);
6195 	ieee80211_hw_set(ar->hw, REPORTS_TX_ACK_STATUS);
6196 	ieee80211_hw_set(ar->hw, HAS_RATE_CONTROL);
6197 	ieee80211_hw_set(ar->hw, AP_LINK_PS);
6198 	ieee80211_hw_set(ar->hw, SPECTRUM_MGMT);
6199 	ieee80211_hw_set(ar->hw, CONNECTION_MONITOR);
6200 	ieee80211_hw_set(ar->hw, SUPPORTS_PER_STA_GTK);
6201 	ieee80211_hw_set(ar->hw, WANT_MONITOR_VIF);
6202 	ieee80211_hw_set(ar->hw, CHANCTX_STA_CSA);
6203 	ieee80211_hw_set(ar->hw, QUEUE_CONTROL);
6204 	ieee80211_hw_set(ar->hw, SUPPORTS_TX_FRAG);
6205 	ieee80211_hw_set(ar->hw, REPORTS_LOW_ACK);
6206 	ieee80211_hw_set(ar->hw, SUPPORTS_TX_ENCAP_OFFLOAD);
6207 	if (ht_cap & WMI_HT_CAP_ENABLED) {
6208 		ieee80211_hw_set(ar->hw, AMPDU_AGGREGATION);
6209 		ieee80211_hw_set(ar->hw, TX_AMPDU_SETUP_IN_HW);
6210 		ieee80211_hw_set(ar->hw, SUPPORTS_REORDERING_BUFFER);
6211 		ieee80211_hw_set(ar->hw, SUPPORTS_AMSDU_IN_AMPDU);
6212 		ieee80211_hw_set(ar->hw, USES_RSS);
6213 	}
6214 
6215 	ar->hw->wiphy->features |= NL80211_FEATURE_STATIC_SMPS;
6216 	ar->hw->wiphy->flags |= WIPHY_FLAG_IBSS_RSN;
6217 
6218 	/* TODO: Check if HT capability advertised from firmware is different
6219 	 * for each band for a dual band capable radio. It will be tricky to
6220 	 * handle it when the ht capability different for each band.
6221 	 */
6222 	if (ht_cap & WMI_HT_CAP_DYNAMIC_SMPS)
6223 		ar->hw->wiphy->features |= NL80211_FEATURE_DYNAMIC_SMPS;
6224 
6225 	ar->hw->wiphy->max_scan_ssids = WLAN_SCAN_PARAMS_MAX_SSID;
6226 	ar->hw->wiphy->max_scan_ie_len = WLAN_SCAN_PARAMS_MAX_IE_LEN;
6227 
6228 	ar->hw->max_listen_interval = ATH11K_MAX_HW_LISTEN_INTERVAL;
6229 
6230 	ar->hw->wiphy->flags |= WIPHY_FLAG_HAS_REMAIN_ON_CHANNEL;
6231 	ar->hw->wiphy->flags |= WIPHY_FLAG_HAS_CHANNEL_SWITCH;
6232 	ar->hw->wiphy->max_remain_on_channel_duration = 5000;
6233 
6234 	ar->hw->wiphy->flags |= WIPHY_FLAG_AP_UAPSD;
6235 	ar->hw->wiphy->features |= NL80211_FEATURE_AP_MODE_CHAN_WIDTH_CHANGE |
6236 				   NL80211_FEATURE_AP_SCAN;
6237 
6238 	ar->max_num_stations = TARGET_NUM_STATIONS;
6239 	ar->max_num_peers = TARGET_NUM_PEERS_PDEV;
6240 
6241 	ar->hw->wiphy->max_ap_assoc_sta = ar->max_num_stations;
6242 
6243 	ar->hw->queues = ATH11K_HW_MAX_QUEUES;
6244 	ar->hw->wiphy->tx_queue_len = ATH11K_QUEUE_LEN;
6245 	ar->hw->offchannel_tx_hw_queue = ATH11K_HW_MAX_QUEUES - 1;
6246 	ar->hw->max_rx_aggregation_subframes = IEEE80211_MAX_AMPDU_BUF;
6247 
6248 	ar->hw->vif_data_size = sizeof(struct ath11k_vif);
6249 	ar->hw->sta_data_size = sizeof(struct ath11k_sta);
6250 
6251 	wiphy_ext_feature_set(ar->hw->wiphy, NL80211_EXT_FEATURE_CQM_RSSI_LIST);
6252 	wiphy_ext_feature_set(ar->hw->wiphy, NL80211_EXT_FEATURE_STA_TX_PWR);
6253 
6254 	ar->hw->wiphy->cipher_suites = cipher_suites;
6255 	ar->hw->wiphy->n_cipher_suites = ARRAY_SIZE(cipher_suites);
6256 
6257 	ar->hw->wiphy->iftype_ext_capab = ath11k_iftypes_ext_capa;
6258 	ar->hw->wiphy->num_iftype_ext_capab =
6259 		ARRAY_SIZE(ath11k_iftypes_ext_capa);
6260 
6261 	ath11k_reg_init(ar);
6262 
6263 	if (!test_bit(ATH11K_FLAG_RAW_MODE, &ab->dev_flags)) {
6264 		ar->hw->netdev_features = NETIF_F_HW_CSUM;
6265 		ieee80211_hw_set(ar->hw, SW_CRYPTO_CONTROL);
6266 		ieee80211_hw_set(ar->hw, SUPPORT_FAST_XMIT);
6267 	}
6268 
6269 	ret = ieee80211_register_hw(ar->hw);
6270 	if (ret) {
6271 		ath11k_err(ar->ab, "ieee80211 registration failed: %d\n", ret);
6272 		goto err_free_if_combs;
6273 	}
6274 
6275 	if (!ab->hw_params.supports_monitor)
6276 		/* There's a race between calling ieee80211_register_hw()
6277 		 * and here where the monitor mode is enabled for a little
6278 		 * while. But that time is so short and in practise it make
6279 		 * a difference in real life.
6280 		 */
6281 		ar->hw->wiphy->interface_modes &= ~BIT(NL80211_IFTYPE_MONITOR);
6282 
6283 	/* Apply the regd received during initialization */
6284 	ret = ath11k_regd_update(ar, true);
6285 	if (ret) {
6286 		ath11k_err(ar->ab, "ath11k regd update failed: %d\n", ret);
6287 		goto err_free_if_combs;
6288 	}
6289 
6290 	ret = ath11k_debugfs_register(ar);
6291 	if (ret) {
6292 		ath11k_err(ar->ab, "debugfs registration failed: %d\n", ret);
6293 		goto err_free_if_combs;
6294 	}
6295 
6296 	return 0;
6297 
6298 err_free_if_combs:
6299 	kfree(ar->hw->wiphy->iface_combinations[0].limits);
6300 	kfree(ar->hw->wiphy->iface_combinations);
6301 
6302 err_free_channels:
6303 	kfree(ar->mac.sbands[NL80211_BAND_2GHZ].channels);
6304 	kfree(ar->mac.sbands[NL80211_BAND_5GHZ].channels);
6305 	kfree(ar->mac.sbands[NL80211_BAND_6GHZ].channels);
6306 
6307 err:
6308 	SET_IEEE80211_DEV(ar->hw, NULL);
6309 	return ret;
6310 }
6311 
6312 int ath11k_mac_register(struct ath11k_base *ab)
6313 {
6314 	struct ath11k *ar;
6315 	struct ath11k_pdev *pdev;
6316 	int i;
6317 	int ret;
6318 
6319 	if (test_bit(ATH11K_FLAG_REGISTERED, &ab->dev_flags))
6320 		return 0;
6321 
6322 	for (i = 0; i < ab->num_radios; i++) {
6323 		pdev = &ab->pdevs[i];
6324 		ar = pdev->ar;
6325 		if (ab->pdevs_macaddr_valid) {
6326 			ether_addr_copy(ar->mac_addr, pdev->mac_addr);
6327 		} else {
6328 			ether_addr_copy(ar->mac_addr, ab->mac_addr);
6329 			ar->mac_addr[4] += i;
6330 		}
6331 
6332 		ret = __ath11k_mac_register(ar);
6333 		if (ret)
6334 			goto err_cleanup;
6335 
6336 		idr_init(&ar->txmgmt_idr);
6337 		spin_lock_init(&ar->txmgmt_idr_lock);
6338 	}
6339 
6340 	/* Initialize channel counters frequency value in hertz */
6341 	ab->cc_freq_hz = IPQ8074_CC_FREQ_HERTZ;
6342 	ab->free_vdev_map = (1LL << (ab->num_radios * TARGET_NUM_VDEVS)) - 1;
6343 
6344 	return 0;
6345 
6346 err_cleanup:
6347 	for (i = i - 1; i >= 0; i--) {
6348 		pdev = &ab->pdevs[i];
6349 		ar = pdev->ar;
6350 		__ath11k_mac_unregister(ar);
6351 	}
6352 
6353 	return ret;
6354 }
6355 
6356 int ath11k_mac_allocate(struct ath11k_base *ab)
6357 {
6358 	struct ieee80211_hw *hw;
6359 	struct ath11k *ar;
6360 	struct ath11k_pdev *pdev;
6361 	int ret;
6362 	int i;
6363 
6364 	if (test_bit(ATH11K_FLAG_REGISTERED, &ab->dev_flags))
6365 		return 0;
6366 
6367 	for (i = 0; i < ab->num_radios; i++) {
6368 		pdev = &ab->pdevs[i];
6369 		hw = ieee80211_alloc_hw(sizeof(struct ath11k), &ath11k_ops);
6370 		if (!hw) {
6371 			ath11k_warn(ab, "failed to allocate mac80211 hw device\n");
6372 			ret = -ENOMEM;
6373 			goto err_free_mac;
6374 		}
6375 
6376 		ar = hw->priv;
6377 		ar->hw = hw;
6378 		ar->ab = ab;
6379 		ar->pdev = pdev;
6380 		ar->pdev_idx = i;
6381 		ar->lmac_id = ath11k_hw_get_mac_from_pdev_id(&ab->hw_params, i);
6382 
6383 		ar->wmi = &ab->wmi_ab.wmi[i];
6384 		/* FIXME wmi[0] is already initialized during attach,
6385 		 * Should we do this again?
6386 		 */
6387 		ath11k_wmi_pdev_attach(ab, i);
6388 
6389 		ar->cfg_tx_chainmask = pdev->cap.tx_chain_mask;
6390 		ar->cfg_rx_chainmask = pdev->cap.rx_chain_mask;
6391 		ar->num_tx_chains = get_num_chains(pdev->cap.tx_chain_mask);
6392 		ar->num_rx_chains = get_num_chains(pdev->cap.rx_chain_mask);
6393 
6394 		pdev->ar = ar;
6395 		spin_lock_init(&ar->data_lock);
6396 		INIT_LIST_HEAD(&ar->arvifs);
6397 		INIT_LIST_HEAD(&ar->ppdu_stats_info);
6398 		mutex_init(&ar->conf_mutex);
6399 		init_completion(&ar->vdev_setup_done);
6400 		init_completion(&ar->peer_assoc_done);
6401 		init_completion(&ar->install_key_done);
6402 		init_completion(&ar->bss_survey_done);
6403 		init_completion(&ar->scan.started);
6404 		init_completion(&ar->scan.completed);
6405 		init_completion(&ar->thermal.wmi_sync);
6406 
6407 		INIT_DELAYED_WORK(&ar->scan.timeout, ath11k_scan_timeout_work);
6408 		INIT_WORK(&ar->regd_update_work, ath11k_regd_update_work);
6409 
6410 		INIT_WORK(&ar->wmi_mgmt_tx_work, ath11k_mgmt_over_wmi_tx_work);
6411 		skb_queue_head_init(&ar->wmi_mgmt_tx_queue);
6412 		clear_bit(ATH11K_FLAG_MONITOR_ENABLED, &ar->monitor_flags);
6413 	}
6414 
6415 	return 0;
6416 
6417 err_free_mac:
6418 	ath11k_mac_destroy(ab);
6419 
6420 	return ret;
6421 }
6422 
6423 void ath11k_mac_destroy(struct ath11k_base *ab)
6424 {
6425 	struct ath11k *ar;
6426 	struct ath11k_pdev *pdev;
6427 	int i;
6428 
6429 	for (i = 0; i < ab->num_radios; i++) {
6430 		pdev = &ab->pdevs[i];
6431 		ar = pdev->ar;
6432 		if (!ar)
6433 			continue;
6434 
6435 		ieee80211_free_hw(ar->hw);
6436 		pdev->ar = NULL;
6437 	}
6438 }
6439