1 // SPDX-License-Identifier: ISC
2 /* Copyright (C) 2020 MediaTek Inc. */
5 #include <linux/firmware.h>
8 #include "../mt76_connac2_mac.h"
9 #include "../mt792x_trace.h"
11 #define MT_STA_BFER BIT(0)
12 #define MT_STA_BFEE BIT(1)
14 static bool mt7921_disable_clc;
15 module_param_named(disable_clc, mt7921_disable_clc, bool, 0644);
16 MODULE_PARM_DESC(disable_clc, "disable CLC support");
18 int mt7921_mcu_parse_response(struct mt76_dev *mdev, int cmd,
19 struct sk_buff *skb, int seq)
21 int mcu_cmd = FIELD_GET(__MCU_CMD_FIELD_ID, cmd);
22 struct mt76_connac2_mcu_rxd *rxd;
26 dev_err(mdev->dev, "Message %08x (seq %d) timeout\n",
33 rxd = (struct mt76_connac2_mcu_rxd *)skb->data;
37 if (cmd == MCU_CMD(PATCH_SEM_CONTROL) ||
38 cmd == MCU_CMD(PATCH_FINISH_REQ)) {
39 skb_pull(skb, sizeof(*rxd) - 4);
41 } else if (cmd == MCU_EXT_CMD(THERMAL_CTRL)) {
42 skb_pull(skb, sizeof(*rxd) + 4);
43 ret = le32_to_cpu(*(__le32 *)skb->data);
44 } else if (cmd == MCU_UNI_CMD(DEV_INFO_UPDATE) ||
45 cmd == MCU_UNI_CMD(BSS_INFO_UPDATE) ||
46 cmd == MCU_UNI_CMD(STA_REC_UPDATE) ||
47 cmd == MCU_UNI_CMD(HIF_CTRL) ||
48 cmd == MCU_UNI_CMD(OFFLOAD) ||
49 cmd == MCU_UNI_CMD(SUSPEND)) {
50 struct mt76_connac_mcu_uni_event *event;
52 skb_pull(skb, sizeof(*rxd));
53 event = (struct mt76_connac_mcu_uni_event *)skb->data;
54 ret = le32_to_cpu(event->status);
55 /* skip invalid event */
56 if (mcu_cmd != event->cid)
58 } else if (cmd == MCU_CE_QUERY(REG_READ)) {
59 struct mt76_connac_mcu_reg_event *event;
61 skb_pull(skb, sizeof(*rxd));
62 event = (struct mt76_connac_mcu_reg_event *)skb->data;
63 ret = (int)le32_to_cpu(event->val);
65 skb_pull(skb, sizeof(struct mt76_connac2_mcu_rxd));
70 EXPORT_SYMBOL_GPL(mt7921_mcu_parse_response);
72 static int mt7921_mcu_read_eeprom(struct mt792x_dev *dev, u32 offset, u8 *val)
74 struct mt7921_mcu_eeprom_info *res, req = {
75 .addr = cpu_to_le32(round_down(offset,
76 MT7921_EEPROM_BLOCK_SIZE)),
81 ret = mt76_mcu_send_and_get_msg(&dev->mt76, MCU_EXT_QUERY(EFUSE_ACCESS),
82 &req, sizeof(req), true, &skb);
86 res = (struct mt7921_mcu_eeprom_info *)skb->data;
87 *val = res->data[offset % MT7921_EEPROM_BLOCK_SIZE];
96 mt7921_mcu_set_ipv6_ns_filter(struct mt76_dev *dev,
97 struct ieee80211_vif *vif, bool suspend)
99 struct mt792x_vif *mvif = (struct mt792x_vif *)vif->drv_priv;
105 struct mt76_connac_arpns_tlv arpns;
108 .bss_idx = mvif->mt76.idx,
111 .tag = cpu_to_le16(UNI_OFFLOAD_OFFLOAD_ND),
112 .len = cpu_to_le16(sizeof(struct mt76_connac_arpns_tlv)),
117 return mt76_mcu_send_msg(dev, MCU_UNI_CMD_OFFLOAD, &req, sizeof(req),
121 void mt7921_mcu_set_suspend_iter(void *priv, u8 *mac, struct ieee80211_vif *vif)
123 if (IS_ENABLED(CONFIG_IPV6)) {
124 struct mt76_phy *phy = priv;
126 mt7921_mcu_set_ipv6_ns_filter(phy->dev, vif,
127 !test_bit(MT76_STATE_RUNNING,
131 mt76_connac_mcu_set_suspend_iter(priv, mac, vif);
134 #endif /* CONFIG_PM */
137 mt7921_mcu_uni_roc_event(struct mt792x_dev *dev, struct sk_buff *skb)
139 struct mt7921_roc_grant_tlv *grant;
140 struct mt76_connac2_mcu_rxd *rxd;
143 rxd = (struct mt76_connac2_mcu_rxd *)skb->data;
144 grant = (struct mt7921_roc_grant_tlv *)(rxd->tlv + 4);
146 /* should never happen */
147 WARN_ON_ONCE((le16_to_cpu(grant->tag) != UNI_EVENT_ROC_GRANT));
149 if (grant->reqtype == MT7921_ROC_REQ_ROC)
150 ieee80211_ready_on_channel(dev->mt76.phy.hw);
152 dev->phy.roc_grant = true;
153 wake_up(&dev->phy.roc_wait);
154 duration = le32_to_cpu(grant->max_interval);
155 mod_timer(&dev->phy.roc_timer,
156 jiffies + msecs_to_jiffies(duration));
160 mt7921_mcu_scan_event(struct mt792x_dev *dev, struct sk_buff *skb)
162 struct mt76_phy *mphy = &dev->mt76.phy;
163 struct mt792x_phy *phy = (struct mt792x_phy *)mphy->priv;
165 spin_lock_bh(&dev->mt76.lock);
166 __skb_queue_tail(&phy->scan_event_list, skb);
167 spin_unlock_bh(&dev->mt76.lock);
169 ieee80211_queue_delayed_work(mphy->hw, &phy->scan_work,
170 MT792x_HW_SCAN_TIMEOUT);
174 mt7921_mcu_connection_loss_iter(void *priv, u8 *mac,
175 struct ieee80211_vif *vif)
177 struct mt76_vif *mvif = (struct mt76_vif *)vif->drv_priv;
178 struct mt76_connac_beacon_loss_event *event = priv;
180 if (mvif->idx != event->bss_idx)
183 if (!(vif->driver_flags & IEEE80211_VIF_BEACON_FILTER) ||
184 vif->type != NL80211_IFTYPE_STATION)
187 ieee80211_connection_loss(vif);
191 mt7921_mcu_connection_loss_event(struct mt792x_dev *dev, struct sk_buff *skb)
193 struct mt76_connac_beacon_loss_event *event;
194 struct mt76_phy *mphy = &dev->mt76.phy;
196 skb_pull(skb, sizeof(struct mt76_connac2_mcu_rxd));
197 event = (struct mt76_connac_beacon_loss_event *)skb->data;
199 ieee80211_iterate_active_interfaces_atomic(mphy->hw,
200 IEEE80211_IFACE_ITER_RESUME_ALL,
201 mt7921_mcu_connection_loss_iter, event);
205 mt7921_mcu_debug_msg_event(struct mt792x_dev *dev, struct sk_buff *skb)
207 struct mt7921_debug_msg {
216 skb_pull(skb, sizeof(struct mt76_connac2_mcu_rxd));
217 msg = (struct mt7921_debug_msg *)skb->data;
219 if (msg->type == 3) { /* fw log */
220 u16 len = min_t(u16, le16_to_cpu(msg->len), 512);
223 for (i = 0 ; i < len; i++) {
224 if (!msg->content[i])
225 msg->content[i] = ' ';
227 wiphy_info(mt76_hw(dev)->wiphy, "%.*s", len, msg->content);
232 mt7921_mcu_low_power_event(struct mt792x_dev *dev, struct sk_buff *skb)
234 struct mt7921_mcu_lp_event {
239 skb_pull(skb, sizeof(struct mt76_connac2_mcu_rxd));
240 event = (struct mt7921_mcu_lp_event *)skb->data;
242 trace_lp_event(dev, event->state);
246 mt7921_mcu_tx_done_event(struct mt792x_dev *dev, struct sk_buff *skb)
248 struct mt7921_mcu_tx_done_event *event;
250 skb_pull(skb, sizeof(struct mt76_connac2_mcu_rxd));
251 event = (struct mt7921_mcu_tx_done_event *)skb->data;
253 mt7921_mac_add_txs(dev, event->txs);
257 mt7921_mcu_rx_unsolicited_event(struct mt792x_dev *dev, struct sk_buff *skb)
259 struct mt76_connac2_mcu_rxd *rxd;
261 rxd = (struct mt76_connac2_mcu_rxd *)skb->data;
263 case MCU_EVENT_BSS_BEACON_LOSS:
264 mt7921_mcu_connection_loss_event(dev, skb);
266 case MCU_EVENT_SCHED_SCAN_DONE:
267 case MCU_EVENT_SCAN_DONE:
268 mt7921_mcu_scan_event(dev, skb);
270 case MCU_EVENT_DBG_MSG:
271 mt7921_mcu_debug_msg_event(dev, skb);
273 case MCU_EVENT_COREDUMP:
274 dev->fw_assert = true;
275 mt76_connac_mcu_coredump_event(&dev->mt76, skb,
278 case MCU_EVENT_LP_INFO:
279 mt7921_mcu_low_power_event(dev, skb);
281 case MCU_EVENT_TX_DONE:
282 mt7921_mcu_tx_done_event(dev, skb);
291 mt7921_mcu_uni_rx_unsolicited_event(struct mt792x_dev *dev,
294 struct mt76_connac2_mcu_rxd *rxd;
296 rxd = (struct mt76_connac2_mcu_rxd *)skb->data;
299 case MCU_UNI_EVENT_ROC:
300 mt7921_mcu_uni_roc_event(dev, skb);
308 void mt7921_mcu_rx_event(struct mt792x_dev *dev, struct sk_buff *skb)
310 struct mt76_connac2_mcu_rxd *rxd;
312 if (skb_linearize(skb))
315 rxd = (struct mt76_connac2_mcu_rxd *)skb->data;
317 if (rxd->option & MCU_UNI_CMD_UNSOLICITED_EVENT) {
318 mt7921_mcu_uni_rx_unsolicited_event(dev, skb);
322 if (rxd->eid == 0x6) {
323 mt76_mcu_rx_event(&dev->mt76, skb);
327 if (rxd->ext_eid == MCU_EXT_EVENT_RATE_REPORT ||
328 rxd->eid == MCU_EVENT_BSS_BEACON_LOSS ||
329 rxd->eid == MCU_EVENT_SCHED_SCAN_DONE ||
330 rxd->eid == MCU_EVENT_SCAN_DONE ||
331 rxd->eid == MCU_EVENT_TX_DONE ||
332 rxd->eid == MCU_EVENT_DBG_MSG ||
333 rxd->eid == MCU_EVENT_COREDUMP ||
334 rxd->eid == MCU_EVENT_LP_INFO ||
336 mt7921_mcu_rx_unsolicited_event(dev, skb);
338 mt76_mcu_rx_event(&dev->mt76, skb);
341 /** starec & wtbl **/
342 int mt7921_mcu_uni_tx_ba(struct mt792x_dev *dev,
343 struct ieee80211_ampdu_params *params,
346 struct mt792x_sta *msta = (struct mt792x_sta *)params->sta->drv_priv;
348 if (enable && !params->amsdu)
349 msta->wcid.amsdu = false;
351 return mt76_connac_mcu_sta_ba(&dev->mt76, &msta->vif->mt76, params,
352 MCU_UNI_CMD(STA_REC_UPDATE),
356 int mt7921_mcu_uni_rx_ba(struct mt792x_dev *dev,
357 struct ieee80211_ampdu_params *params,
360 struct mt792x_sta *msta = (struct mt792x_sta *)params->sta->drv_priv;
362 return mt76_connac_mcu_sta_ba(&dev->mt76, &msta->vif->mt76, params,
363 MCU_UNI_CMD(STA_REC_UPDATE),
367 static int mt7921_load_clc(struct mt792x_dev *dev, const char *fw_name)
369 const struct mt76_connac2_fw_trailer *hdr;
370 const struct mt76_connac2_fw_region *region;
371 const struct mt7921_clc *clc;
372 struct mt76_dev *mdev = &dev->mt76;
373 struct mt792x_phy *phy = &dev->phy;
374 const struct firmware *fw;
375 int ret, i, len, offset = 0;
376 u8 *clc_base = NULL, hw_encap = 0;
378 if (mt7921_disable_clc ||
379 mt76_is_usb(&dev->mt76))
382 if (mt76_is_mmio(&dev->mt76)) {
383 ret = mt7921_mcu_read_eeprom(dev, MT_EE_HW_TYPE, &hw_encap);
386 hw_encap = u8_get_bits(hw_encap, MT_EE_HW_TYPE_ENCAP);
389 ret = request_firmware(&fw, fw_name, mdev->dev);
393 if (!fw || !fw->data || fw->size < sizeof(*hdr)) {
394 dev_err(mdev->dev, "Invalid firmware\n");
399 hdr = (const void *)(fw->data + fw->size - sizeof(*hdr));
400 for (i = 0; i < hdr->n_region; i++) {
401 region = (const void *)((const u8 *)hdr -
402 (hdr->n_region - i) * sizeof(*region));
403 len = le32_to_cpu(region->len);
405 /* check if we have valid buffer size */
406 if (offset + len > fw->size) {
407 dev_err(mdev->dev, "Invalid firmware region\n");
412 if ((region->feature_set & FW_FEATURE_NON_DL) &&
413 region->type == FW_TYPE_CLC) {
414 clc_base = (u8 *)(fw->data + offset);
423 for (offset = 0; offset < len; offset += le32_to_cpu(clc->len)) {
424 clc = (const struct mt7921_clc *)(clc_base + offset);
426 /* do not init buf again if chip reset triggered */
427 if (phy->clc[clc->idx])
430 /* header content sanity */
431 if (clc->idx == MT7921_CLC_POWER &&
432 u8_get_bits(clc->type, MT_EE_HW_TYPE_ENCAP) != hw_encap)
435 phy->clc[clc->idx] = devm_kmemdup(mdev->dev, clc,
436 le32_to_cpu(clc->len),
439 if (!phy->clc[clc->idx]) {
444 ret = mt7921_mcu_set_clc(dev, "00", ENVIRON_INDOOR);
446 release_firmware(fw);
451 static void mt7921_mcu_parse_tx_resource(struct mt76_dev *dev,
454 struct mt76_sdio *sdio = &dev->sdio;
455 struct mt7921_tx_resource {
457 __le32 pse_data_quota;
458 __le32 pse_mcu_quota;
459 __le32 ple_data_quota;
460 __le32 ple_mcu_quota;
461 __le16 pse_page_size;
462 __le16 ple_page_size;
467 tx_res = (struct mt7921_tx_resource *)skb->data;
468 sdio->sched.pse_data_quota = le32_to_cpu(tx_res->pse_data_quota);
469 sdio->sched.pse_mcu_quota = le32_to_cpu(tx_res->pse_mcu_quota);
470 sdio->sched.ple_data_quota = le32_to_cpu(tx_res->ple_data_quota);
471 sdio->sched.pse_page_size = le16_to_cpu(tx_res->pse_page_size);
472 sdio->sched.deficit = tx_res->pp_padding;
475 static void mt7921_mcu_parse_phy_cap(struct mt76_dev *dev,
478 struct mt7921_phy_cap {
498 cap = (struct mt7921_phy_cap *)skb->data;
500 dev->phy.antenna_mask = BIT(cap->nss) - 1;
501 dev->phy.chainmask = dev->phy.antenna_mask;
502 dev->phy.cap.has_2ghz = cap->hw_path & BIT(WF0_24G);
503 dev->phy.cap.has_5ghz = cap->hw_path & BIT(WF0_5G);
506 static int mt7921_mcu_get_nic_capability(struct mt792x_phy *mphy)
508 struct mt76_connac_cap_hdr {
513 struct mt76_phy *phy = mphy->mt76;
516 ret = mt76_mcu_send_and_get_msg(phy->dev, MCU_CE_CMD(GET_NIC_CAPAB),
517 NULL, 0, true, &skb);
521 hdr = (struct mt76_connac_cap_hdr *)skb->data;
522 if (skb->len < sizeof(*hdr)) {
527 skb_pull(skb, sizeof(*hdr));
529 for (i = 0; i < le16_to_cpu(hdr->n_element); i++) {
533 } __packed * tlv = (struct tlv_hdr *)skb->data;
536 if (skb->len < sizeof(*tlv))
539 skb_pull(skb, sizeof(*tlv));
541 len = le32_to_cpu(tlv->len);
545 switch (le32_to_cpu(tlv->type)) {
547 phy->cap.has_6ghz = skb->data[0];
549 case MT_NIC_CAP_MAC_ADDR:
550 memcpy(phy->macaddr, (void *)skb->data, ETH_ALEN);
553 mt7921_mcu_parse_phy_cap(phy->dev, skb);
555 case MT_NIC_CAP_TX_RESOURCE:
556 if (mt76_is_sdio(phy->dev))
557 mt7921_mcu_parse_tx_resource(phy->dev,
571 int mt7921_mcu_fw_log_2_host(struct mt792x_dev *dev, u8 ctrl)
580 return mt76_mcu_send_msg(&dev->mt76, MCU_CE_CMD(FWLOG_2_HOST),
581 &data, sizeof(data), false);
584 int mt7921_run_firmware(struct mt792x_dev *dev)
588 err = mt792x_load_firmware(dev);
592 err = mt7921_mcu_get_nic_capability(&dev->phy);
596 set_bit(MT76_STATE_MCU_RUNNING, &dev->mphy.state);
597 err = mt7921_load_clc(dev, mt792x_ram_name(dev));
601 return mt7921_mcu_fw_log_2_host(dev, 1);
603 EXPORT_SYMBOL_GPL(mt7921_run_firmware);
605 int mt7921_mcu_set_tx(struct mt792x_dev *dev, struct ieee80211_vif *vif)
607 struct mt792x_vif *mvif = (struct mt792x_vif *)vif->drv_priv;
616 struct mt7921_mcu_tx {
617 struct edca edca[IEEE80211_NUM_ACS];
623 .bss_idx = mvif->mt76.idx,
624 .qos = vif->bss_conf.qos,
625 .wmm_idx = mvif->mt76.wmm_idx,
635 struct mt7921_mcu_mu_tx {
643 struct mu_edca edca[IEEE80211_NUM_ACS];
645 } __packed req_mu = {
646 .bss_idx = mvif->mt76.idx,
647 .qos = vif->bss_conf.qos,
648 .wmm_idx = mvif->mt76.wmm_idx,
650 static const int to_aci[] = { 1, 0, 2, 3 };
653 for (ac = 0; ac < IEEE80211_NUM_ACS; ac++) {
654 struct ieee80211_tx_queue_params *q = &mvif->queue_params[ac];
655 struct edca *e = &req.edca[to_aci[ac]];
657 e->aifs = cpu_to_le16(q->aifs);
658 e->txop = cpu_to_le16(q->txop);
661 e->cw_min = cpu_to_le16(q->cw_min);
663 e->cw_min = cpu_to_le16(5);
666 e->cw_max = cpu_to_le16(q->cw_max);
668 e->cw_max = cpu_to_le16(10);
671 ret = mt76_mcu_send_msg(&dev->mt76, MCU_CE_CMD(SET_EDCA_PARMS), &req,
676 if (!vif->bss_conf.he_support)
679 for (ac = 0; ac < IEEE80211_NUM_ACS; ac++) {
680 struct ieee80211_he_mu_edca_param_ac_rec *q;
683 if (!mvif->queue_params[ac].mu_edca)
686 q = &mvif->queue_params[ac].mu_edca_param_rec;
687 e = &(req_mu.edca[to_aci[ac]]);
689 e->cw_min = q->ecw_min_max & 0xf;
690 e->cw_max = (q->ecw_min_max & 0xf0) >> 4;
692 e->timer = q->mu_edca_timer;
695 return mt76_mcu_send_msg(&dev->mt76, MCU_CE_CMD(SET_MU_EDCA_PARMS),
696 &req_mu, sizeof(req_mu), false);
699 int mt7921_mcu_set_roc(struct mt792x_phy *phy, struct mt792x_vif *vif,
700 struct ieee80211_channel *chan, int duration,
701 enum mt7921_roc_req type, u8 token_id)
703 int center_ch = ieee80211_frequency_to_channel(chan->center_freq);
704 struct mt792x_dev *dev = phy->dev;
709 struct roc_acquire_tlv {
721 u8 center_chan_from_ap;
722 u8 center_chan2_from_ap;
730 .tag = cpu_to_le16(UNI_ROC_ACQUIRE),
731 .len = cpu_to_le16(sizeof(struct roc_acquire_tlv)),
734 .maxinterval = cpu_to_le32(duration),
735 .bss_idx = vif->mt76.idx,
736 .control_channel = chan->hw_value,
738 .bw_from_ap = CMD_CBW_20MHZ,
739 .center_chan = center_ch,
740 .center_chan_from_ap = center_ch,
741 .dbdcband = 0xff, /* auto */
745 if (chan->hw_value < center_ch)
746 req.roc.sco = 1; /* SCA */
747 else if (chan->hw_value > center_ch)
748 req.roc.sco = 3; /* SCB */
750 switch (chan->band) {
751 case NL80211_BAND_6GHZ:
754 case NL80211_BAND_5GHZ:
762 return mt76_mcu_send_msg(&dev->mt76, MCU_UNI_CMD(ROC),
763 &req, sizeof(req), false);
766 int mt7921_mcu_abort_roc(struct mt792x_phy *phy, struct mt792x_vif *vif,
769 struct mt792x_dev *dev = phy->dev;
774 struct roc_abort_tlv {
784 .tag = cpu_to_le16(UNI_ROC_ABORT),
785 .len = cpu_to_le16(sizeof(struct roc_abort_tlv)),
787 .bss_idx = vif->mt76.idx,
788 .dbdcband = 0xff, /* auto*/
792 return mt76_mcu_send_msg(&dev->mt76, MCU_UNI_CMD(ROC),
793 &req, sizeof(req), false);
796 int mt7921_mcu_set_chan_info(struct mt792x_phy *phy, int cmd)
798 struct mt792x_dev *dev = phy->dev;
799 struct cfg80211_chan_def *chandef = &phy->mt76->chandef;
800 int freq1 = chandef->center_freq1;
806 u8 rx_streams; /* mask or num */
809 u8 center_ch2; /* for 80+80 only */
819 .control_ch = chandef->chan->hw_value,
820 .center_ch = ieee80211_frequency_to_channel(freq1),
821 .bw = mt76_connac_chan_bw(chandef),
822 .tx_streams_num = hweight8(phy->mt76->antenna_mask),
823 .rx_streams = phy->mt76->antenna_mask,
824 .band_idx = phy != &dev->phy,
827 if (chandef->chan->band == NL80211_BAND_6GHZ)
828 req.channel_band = 2;
830 req.channel_band = chandef->chan->band;
832 if (cmd == MCU_EXT_CMD(SET_RX_PATH) ||
833 dev->mt76.hw->conf.flags & IEEE80211_CONF_MONITOR)
834 req.switch_reason = CH_SWITCH_NORMAL;
835 else if (dev->mt76.hw->conf.flags & IEEE80211_CONF_OFFCHANNEL)
836 req.switch_reason = CH_SWITCH_SCAN_BYPASS_DPD;
837 else if (!cfg80211_reg_can_beacon(dev->mt76.hw->wiphy, chandef,
839 req.switch_reason = CH_SWITCH_DFS;
841 req.switch_reason = CH_SWITCH_NORMAL;
843 if (cmd == MCU_EXT_CMD(CHANNEL_SWITCH))
844 req.rx_streams = hweight8(req.rx_streams);
846 if (chandef->width == NL80211_CHAN_WIDTH_80P80) {
847 int freq2 = chandef->center_freq2;
849 req.center_ch2 = ieee80211_frequency_to_channel(freq2);
852 return mt76_mcu_send_msg(&dev->mt76, cmd, &req, sizeof(req), true);
855 int mt7921_mcu_set_eeprom(struct mt792x_dev *dev)
862 .buffer_mode = EE_MODE_EFUSE,
863 .format = EE_FORMAT_WHOLE,
866 return mt76_mcu_send_msg(&dev->mt76, MCU_EXT_CMD(EFUSE_BUFFER_MODE),
867 &req, sizeof(req), true);
869 EXPORT_SYMBOL_GPL(mt7921_mcu_set_eeprom);
871 int mt7921_mcu_uni_bss_ps(struct mt792x_dev *dev, struct ieee80211_vif *vif)
873 struct mt792x_vif *mvif = (struct mt792x_vif *)vif->drv_priv;
882 u8 ps_state; /* 0: device awake
883 * 1: static power save
884 * 2: dynamic power saving
885 * 3: enter TWT power saving
886 * 4: leave TWT power saving
890 } __packed ps_req = {
892 .bss_idx = mvif->mt76.idx,
895 .tag = cpu_to_le16(UNI_BSS_INFO_PS),
896 .len = cpu_to_le16(sizeof(struct ps_tlv)),
897 .ps_state = vif->cfg.ps ? 2 : 0,
901 if (vif->type != NL80211_IFTYPE_STATION)
904 return mt76_mcu_send_msg(&dev->mt76, MCU_UNI_CMD(BSS_INFO_UPDATE),
905 &ps_req, sizeof(ps_req), true);
909 mt7921_mcu_uni_bss_bcnft(struct mt792x_dev *dev, struct ieee80211_vif *vif,
912 struct mt792x_vif *mvif = (struct mt792x_vif *)vif->drv_priv;
925 } __packed bcnft_req = {
927 .bss_idx = mvif->mt76.idx,
930 .tag = cpu_to_le16(UNI_BSS_INFO_BCNFT),
931 .len = cpu_to_le16(sizeof(struct bcnft_tlv)),
932 .bcn_interval = cpu_to_le16(vif->bss_conf.beacon_int),
933 .dtim_period = vif->bss_conf.dtim_period,
937 if (vif->type != NL80211_IFTYPE_STATION)
940 return mt76_mcu_send_msg(&dev->mt76, MCU_UNI_CMD(BSS_INFO_UPDATE),
941 &bcnft_req, sizeof(bcnft_req), true);
945 mt7921_mcu_set_bss_pm(struct mt792x_dev *dev, struct ieee80211_vif *vif,
948 struct mt792x_vif *mvif = (struct mt792x_vif *)vif->drv_priv;
960 .bss_idx = mvif->mt76.idx,
961 .aid = cpu_to_le16(vif->cfg.aid),
962 .dtim_period = vif->bss_conf.dtim_period,
963 .bcn_interval = cpu_to_le16(vif->bss_conf.beacon_int),
969 .bss_idx = mvif->mt76.idx,
973 err = mt76_mcu_send_msg(&dev->mt76, MCU_CE_CMD(SET_BSS_ABORT),
974 &req_hdr, sizeof(req_hdr), false);
975 if (err < 0 || !enable)
978 return mt76_mcu_send_msg(&dev->mt76, MCU_CE_CMD(SET_BSS_CONNECTED),
979 &req, sizeof(req), false);
982 int mt7921_mcu_sta_update(struct mt792x_dev *dev, struct ieee80211_sta *sta,
983 struct ieee80211_vif *vif, bool enable,
984 enum mt76_sta_info_state state)
986 struct mt792x_vif *mvif = (struct mt792x_vif *)vif->drv_priv;
987 int rssi = -ewma_rssi_read(&mvif->rssi);
988 struct mt76_sta_cmd_info info = {
992 .cmd = MCU_UNI_CMD(STA_REC_UPDATE),
995 .rcpi = to_rcpi(rssi),
997 struct mt792x_sta *msta;
999 msta = sta ? (struct mt792x_sta *)sta->drv_priv : NULL;
1000 info.wcid = msta ? &msta->wcid : &mvif->sta.wcid;
1001 info.newly = msta ? state != MT76_STA_INFO_STATE_ASSOC : true;
1003 return mt76_connac_mcu_sta_cmd(&dev->mphy, &info);
1006 int mt7921_mcu_set_beacon_filter(struct mt792x_dev *dev,
1007 struct ieee80211_vif *vif,
1010 #define MT7921_FIF_BIT_CLR BIT(1)
1011 #define MT7921_FIF_BIT_SET BIT(0)
1015 err = mt7921_mcu_uni_bss_bcnft(dev, vif, true);
1019 err = mt7921_mcu_set_rxfilter(dev, 0,
1021 MT_WF_RFCR_DROP_OTHER_BEACON);
1028 err = mt7921_mcu_set_bss_pm(dev, vif, false);
1032 err = mt7921_mcu_set_rxfilter(dev, 0,
1034 MT_WF_RFCR_DROP_OTHER_BEACON);
1041 int mt7921_get_txpwr_info(struct mt792x_dev *dev, struct mt7921_txpwr *txpwr)
1043 struct mt7921_txpwr_event *event;
1044 struct mt7921_txpwr_req req = {
1047 struct sk_buff *skb;
1050 ret = mt76_mcu_send_and_get_msg(&dev->mt76, MCU_CE_CMD(GET_TXPWR),
1051 &req, sizeof(req), true, &skb);
1055 event = (struct mt7921_txpwr_event *)skb->data;
1056 WARN_ON(skb->len != le16_to_cpu(event->len));
1057 memcpy(txpwr, &event->txpwr, sizeof(event->txpwr));
1064 int mt7921_mcu_set_sniffer(struct mt792x_dev *dev, struct ieee80211_vif *vif,
1067 struct mt76_vif *mvif = (struct mt76_vif *)vif->drv_priv;
1073 struct sniffer_enable_tlv {
1081 .band_idx = mvif->band_idx,
1084 .tag = cpu_to_le16(0),
1085 .len = cpu_to_le16(sizeof(struct sniffer_enable_tlv)),
1090 return mt76_mcu_send_msg(&dev->mt76, MCU_UNI_CMD(SNIFFER), &req, sizeof(req),
1094 int mt7921_mcu_config_sniffer(struct mt792x_vif *vif,
1095 struct ieee80211_chanctx_conf *ctx)
1097 struct cfg80211_chan_def *chandef = &ctx->def;
1098 int freq1 = chandef->center_freq1, freq2 = chandef->center_freq2;
1099 const u8 ch_band[] = {
1100 [NL80211_BAND_2GHZ] = 1,
1101 [NL80211_BAND_5GHZ] = 2,
1102 [NL80211_BAND_6GHZ] = 3,
1104 const u8 ch_width[] = {
1105 [NL80211_CHAN_WIDTH_20_NOHT] = 0,
1106 [NL80211_CHAN_WIDTH_20] = 0,
1107 [NL80211_CHAN_WIDTH_40] = 0,
1108 [NL80211_CHAN_WIDTH_80] = 1,
1109 [NL80211_CHAN_WIDTH_160] = 2,
1110 [NL80211_CHAN_WIDTH_80P80] = 3,
1111 [NL80211_CHAN_WIDTH_5] = 4,
1112 [NL80211_CHAN_WIDTH_10] = 5,
1113 [NL80211_CHAN_WIDTH_320] = 6,
1135 .band_idx = vif->mt76.band_idx,
1138 .tag = cpu_to_le16(1),
1139 .len = cpu_to_le16(sizeof(req.tlv)),
1140 .control_ch = chandef->chan->hw_value,
1141 .center_ch = ieee80211_frequency_to_channel(freq1),
1145 if (chandef->chan->band < ARRAY_SIZE(ch_band))
1146 req.tlv.ch_band = ch_band[chandef->chan->band];
1147 if (chandef->width < ARRAY_SIZE(ch_width))
1148 req.tlv.bw = ch_width[chandef->width];
1151 req.tlv.center_ch2 = ieee80211_frequency_to_channel(freq2);
1153 if (req.tlv.control_ch < req.tlv.center_ch)
1154 req.tlv.sco = 1; /* SCA */
1155 else if (req.tlv.control_ch > req.tlv.center_ch)
1156 req.tlv.sco = 3; /* SCB */
1158 return mt76_mcu_send_msg(vif->phy->mt76->dev, MCU_UNI_CMD(SNIFFER),
1159 &req, sizeof(req), true);
1163 mt7921_mcu_uni_add_beacon_offload(struct mt792x_dev *dev,
1164 struct ieee80211_hw *hw,
1165 struct ieee80211_vif *vif,
1168 struct mt792x_vif *mvif = (struct mt792x_vif *)vif->drv_priv;
1169 struct mt76_wcid *wcid = &dev->mt76.global_wcid;
1170 struct ieee80211_mutable_offsets offs;
1176 struct bcn_content_tlv {
1182 /* 0: disable beacon offload
1183 * 1: enable beacon offload
1184 * 2: update probe respond offload
1187 /* 0: legacy format (TXD + payload)
1188 * 1: only cap field IE
1193 } __packed beacon_tlv;
1196 .bss_idx = mvif->mt76.idx,
1199 .tag = cpu_to_le16(UNI_BSS_INFO_BCN_CONTENT),
1200 .len = cpu_to_le16(sizeof(struct bcn_content_tlv)),
1204 struct sk_buff *skb;
1206 /* support enable/update process only
1207 * disable flow would be handled in bss stop handler automatically
1212 skb = ieee80211_beacon_get_template(mt76_hw(dev), vif, &offs, 0);
1216 if (skb->len > 512 - MT_TXD_SIZE) {
1217 dev_err(dev->mt76.dev, "beacon size limit exceed\n");
1222 mt76_connac2_mac_write_txwi(&dev->mt76, (__le32 *)(req.beacon_tlv.pkt),
1223 skb, wcid, NULL, 0, 0, BSS_CHANGED_BEACON);
1224 memcpy(req.beacon_tlv.pkt + MT_TXD_SIZE, skb->data, skb->len);
1225 req.beacon_tlv.pkt_len = cpu_to_le16(MT_TXD_SIZE + skb->len);
1226 req.beacon_tlv.tim_ie_pos = cpu_to_le16(MT_TXD_SIZE + offs.tim_offset);
1228 if (offs.cntdwn_counter_offs[0]) {
1231 csa_offs = MT_TXD_SIZE + offs.cntdwn_counter_offs[0] - 4;
1232 req.beacon_tlv.csa_ie_pos = cpu_to_le16(csa_offs);
1236 return mt76_mcu_send_msg(&dev->mt76, MCU_UNI_CMD(BSS_INFO_UPDATE),
1237 &req, sizeof(req), true);
1241 int __mt7921_mcu_set_clc(struct mt792x_dev *dev, u8 *alpha2,
1242 enum environment_cap env_cap,
1243 struct mt7921_clc *clc,
1246 struct sk_buff *skb;
1261 .acpi_conf = mt792x_acpi_get_flags(&dev->phy),
1263 int ret, valid_cnt = 0;
1270 for (i = 0; i < clc->nr_country; i++) {
1271 struct mt7921_clc_rule *rule = (struct mt7921_clc_rule *)pos;
1272 u16 len = le16_to_cpu(rule->len);
1274 pos += len + sizeof(*rule);
1275 if (rule->alpha2[0] != alpha2[0] ||
1276 rule->alpha2[1] != alpha2[1])
1279 memcpy(req.alpha2, rule->alpha2, 2);
1280 memcpy(req.type, rule->type, 2);
1282 req.len = cpu_to_le16(sizeof(req) + len);
1283 skb = __mt76_mcu_msg_alloc(&dev->mt76, &req,
1284 le16_to_cpu(req.len),
1285 sizeof(req), GFP_KERNEL);
1288 skb_put_data(skb, rule->data, len);
1290 ret = mt76_mcu_skb_send_msg(&dev->mt76, skb,
1291 MCU_CE_CMD(SET_CLC), false);
1303 int mt7921_mcu_set_clc(struct mt792x_dev *dev, u8 *alpha2,
1304 enum environment_cap env_cap)
1306 struct mt792x_phy *phy = (struct mt792x_phy *)&dev->phy;
1309 /* submit all clc config */
1310 for (i = 0; i < ARRAY_SIZE(phy->clc); i++) {
1311 ret = __mt7921_mcu_set_clc(dev, alpha2, env_cap,
1314 /* If no country found, set "00" as default */
1316 ret = __mt7921_mcu_set_clc(dev, "00",
1325 int mt7921_mcu_get_temperature(struct mt792x_phy *phy)
1327 struct mt792x_dev *dev = phy->dev;
1334 .ctrl_id = THERMAL_SENSOR_TEMP_QUERY,
1335 .band_idx = phy->mt76->band_idx,
1338 return mt76_mcu_send_msg(&dev->mt76, MCU_EXT_CMD(THERMAL_CTRL), &req,
1342 int mt7921_mcu_set_rxfilter(struct mt792x_dev *dev, u32 fif,
1343 u8 bit_op, u32 bit_map)
1350 __le32 bit_map; /* bit_* for bitmap update */
1354 .mode = fif ? 1 : 2,
1355 .fif = cpu_to_le32(fif),
1356 .bit_map = cpu_to_le32(bit_map),
1360 return mt76_mcu_send_msg(&dev->mt76, MCU_CE_CMD(SET_RX_FILTER),
1361 &data, sizeof(data), false);