mt76: mt7915: rely on mt76_connac_mcu_alloc_sta_req
authorLorenzo Bianconi <lorenzo@kernel.org>
Sun, 19 Dec 2021 17:40:08 +0000 (18:40 +0100)
committerFelix Fietkau <nbd@nbd.name>
Thu, 3 Feb 2022 12:57:56 +0000 (13:57 +0100)
Rely on mt76_connac_mcu_alloc_sta_req routine and remove
duplicated code.
Add MT76_CONNAC_LIB module dependency in mt7915 module

Signed-off-by: Lorenzo Bianconi <lorenzo@kernel.org>
Signed-off-by: Felix Fietkau <nbd@nbd.name>
drivers/net/wireless/mediatek/mt76/mt76_connac.h
drivers/net/wireless/mediatek/mt76/mt76_connac_mcu.c
drivers/net/wireless/mediatek/mt76/mt76_connac_mcu.h
drivers/net/wireless/mediatek/mt76/mt7915/Kconfig
drivers/net/wireless/mediatek/mt76/mt7915/mcu.c
drivers/net/wireless/mediatek/mt76/mt7915/mt7915.h

index e7f01c2978a28d0db4c1088ebe44a6a4a95c3598..45ee7b06fba38f47d3971522bbe27d186714de69 100644 (file)
@@ -100,6 +100,11 @@ static inline bool is_mt7663(struct mt76_dev *dev)
        return mt76_chip(dev) == 0x7663;
 }
 
+static inline bool is_mt7915(struct mt76_dev *dev)
+{
+       return mt76_chip(dev) == 0x7915;
+}
+
 int mt76_connac_pm_wake(struct mt76_phy *phy, struct mt76_connac_pm *pm);
 void mt76_connac_power_save_sched(struct mt76_phy *phy,
                                  struct mt76_connac_pm *pm);
index 5664f119447bc4958668d98028a98002d29d88e0..725073416e4cdba08977a06eaba137db593c2e84 100644 (file)
@@ -266,8 +266,8 @@ mt76_connac_mcu_add_nested_tlv(struct sk_buff *skb, int tag, int len,
 EXPORT_SYMBOL_GPL(mt76_connac_mcu_add_nested_tlv);
 
 struct sk_buff *
-mt76_connac_mcu_alloc_sta_req(struct mt76_dev *dev, struct mt76_vif *mvif,
-                             struct mt76_wcid *wcid)
+__mt76_connac_mcu_alloc_sta_req(struct mt76_dev *dev, struct mt76_vif *mvif,
+                               struct mt76_wcid *wcid, int len)
 {
        struct sta_req_hdr hdr = {
                .bss_idx = mvif->idx,
@@ -278,7 +278,7 @@ mt76_connac_mcu_alloc_sta_req(struct mt76_dev *dev, struct mt76_vif *mvif,
 
        mt76_connac_mcu_get_wlan_idx(dev, wcid, &hdr.wlan_idx_lo,
                                     &hdr.wlan_idx_hi);
-       skb = mt76_mcu_msg_alloc(dev, NULL, MT76_CONNAC_STA_UPDATE_MAX_SIZE);
+       skb = mt76_mcu_msg_alloc(dev, NULL, len);
        if (!skb)
                return ERR_PTR(-ENOMEM);
 
@@ -286,7 +286,7 @@ mt76_connac_mcu_alloc_sta_req(struct mt76_dev *dev, struct mt76_vif *mvif,
 
        return skb;
 }
-EXPORT_SYMBOL_GPL(mt76_connac_mcu_alloc_sta_req);
+EXPORT_SYMBOL_GPL(__mt76_connac_mcu_alloc_sta_req);
 
 struct wtbl_req_hdr *
 mt76_connac_mcu_alloc_wtbl_req(struct mt76_dev *dev, struct mt76_wcid *wcid,
index 5baf8370b7bd88c3d23cdfece399b8e3675cea9d..bd93697b7d4b72166bac9fea3824bf83aa7814f0 100644 (file)
@@ -570,6 +570,7 @@ struct wtbl_raw {
                                         sizeof(struct sta_rec_muru) +  \
                                         sizeof(struct sta_rec_bfee) +  \
                                         sizeof(struct sta_rec_ra) +    \
+                                        sizeof(struct sta_rec_sec) +   \
                                         sizeof(struct sta_rec_ra_fixed) + \
                                         sizeof(struct sta_rec_he_6g_capa) + \
                                         sizeof(struct tlv) +           \
@@ -1436,7 +1437,7 @@ mt76_connac_mcu_get_wlan_idx(struct mt76_dev *dev, struct mt76_wcid *wcid,
 {
        *wlan_idx_hi = 0;
 
-       if (is_mt7921(dev)) {
+       if (is_mt7921(dev) || is_mt7915(dev)) {
                *wlan_idx_lo = wcid ? to_wcid_lo(wcid->idx) : 0;
                *wlan_idx_hi = wcid ? to_wcid_hi(wcid->idx) : 0;
        } else {
@@ -1445,8 +1446,16 @@ mt76_connac_mcu_get_wlan_idx(struct mt76_dev *dev, struct mt76_wcid *wcid,
 }
 
 struct sk_buff *
+__mt76_connac_mcu_alloc_sta_req(struct mt76_dev *dev, struct mt76_vif *mvif,
+                               struct mt76_wcid *wcid, int len);
+static inline struct sk_buff *
 mt76_connac_mcu_alloc_sta_req(struct mt76_dev *dev, struct mt76_vif *mvif,
-                             struct mt76_wcid *wcid);
+                             struct mt76_wcid *wcid)
+{
+       return __mt76_connac_mcu_alloc_sta_req(dev, mvif, wcid,
+                                              MT76_CONNAC_STA_UPDATE_MAX_SIZE);
+}
+
 struct wtbl_req_hdr *
 mt76_connac_mcu_alloc_wtbl_req(struct mt76_dev *dev, struct mt76_wcid *wcid,
                               int cmd, void *sta_wtbl, struct sk_buff **skb);
index d98225da694cf799f665a4da7f9dc3dd3fd37200..b8b98cbc2054b78d815fdc7125fcd51a943bfb53 100644 (file)
@@ -1,7 +1,7 @@
 # SPDX-License-Identifier: ISC
 config MT7915E
        tristate "MediaTek MT7915E (PCIe) support"
-       select MT76_CORE
+       select MT76_CONNAC_LIB
        depends on MAC80211
        depends on PCI
        help
index 7b917a093331f4fe4cd64c781bef7e05ec8926ef..bd3151909ac0a8e2921077953093632214cbdc99 100644 (file)
@@ -82,9 +82,6 @@ struct mt7915_fw_region {
 #define PATCH_SEC_TYPE_MASK            GENMASK(15, 0)
 #define PATCH_SEC_TYPE_INFO            0x2
 
-#define to_wcid_lo(id)                 FIELD_GET(GENMASK(7, 0), (u16)id)
-#define to_wcid_hi(id)                 FIELD_GET(GENMASK(9, 8), (u16)id)
-
 #define HE_PHY(p, c)                   u8_get_bits(c, IEEE80211_HE_PHY_##p)
 #define HE_MAC(m, c)                   u8_get_bits(c, IEEE80211_HE_MAC_##m)
 
@@ -577,28 +574,6 @@ void mt7915_mcu_rx_event(struct mt7915_dev *dev, struct sk_buff *skb)
                mt76_mcu_rx_event(&dev->mt76, skb);
 }
 
-static struct sk_buff *
-mt7915_mcu_alloc_sta_req(struct mt7915_dev *dev, struct mt7915_vif *mvif,
-                        struct mt7915_sta *msta, int len)
-{
-       struct sta_req_hdr hdr = {
-               .bss_idx = mvif->mt76.idx,
-               .wlan_idx_lo = msta ? to_wcid_lo(msta->wcid.idx) : 0,
-               .wlan_idx_hi = msta ? to_wcid_hi(msta->wcid.idx) : 0,
-               .muar_idx = msta && msta->wcid.sta ? mvif->mt76.omac_idx : 0xe,
-               .is_tlv_append = 1,
-       };
-       struct sk_buff *skb;
-
-       skb = mt76_mcu_msg_alloc(&dev->mt76, NULL, len);
-       if (!skb)
-               return ERR_PTR(-ENOMEM);
-
-       skb_put_data(skb, &hdr, sizeof(hdr));
-
-       return skb;
-}
-
 static struct wtbl_req_hdr *
 mt7915_mcu_alloc_wtbl_req(struct mt7915_dev *dev, struct mt7915_sta *msta,
                          int cmd, void *sta_wtbl, struct sk_buff **skb)
@@ -1010,6 +985,7 @@ int mt7915_mcu_add_bss_info(struct mt7915_phy *phy,
                            struct ieee80211_vif *vif, int enable)
 {
        struct mt7915_vif *mvif = (struct mt7915_vif *)vif->drv_priv;
+       struct mt7915_dev *dev = phy->dev;
        struct sk_buff *skb;
 
        if (mvif->mt76.omac_idx >= REPEATER_BSSID_START) {
@@ -1017,8 +993,8 @@ int mt7915_mcu_add_bss_info(struct mt7915_phy *phy,
                mt7915_mcu_muar_config(phy, vif, true, enable);
        }
 
-       skb = mt7915_mcu_alloc_sta_req(phy->dev, mvif, NULL,
-                                      MT7915_BSS_UPDATE_MAX_SIZE);
+       skb = __mt76_connac_mcu_alloc_sta_req(&dev->mt76, &mvif->mt76, NULL,
+                                             MT7915_BSS_UPDATE_MAX_SIZE);
        if (IS_ERR(skb))
                return PTR_ERR(skb);
 
@@ -1045,7 +1021,7 @@ int mt7915_mcu_add_bss_info(struct mt7915_phy *phy,
                        mt7915_mcu_bss_ext_tlv(skb, mvif);
        }
 out:
-       return mt76_mcu_skb_send_msg(&phy->dev->mt76, skb,
+       return mt76_mcu_skb_send_msg(&dev->mt76, skb,
                                     MCU_EXT_CMD(BSS_INFO_UPDATE), true);
 }
 
@@ -1124,10 +1100,10 @@ int mt7915_mcu_add_key(struct mt7915_dev *dev, struct ieee80211_vif *vif,
 {
        struct mt7915_vif *mvif = (struct mt7915_vif *)vif->drv_priv;
        struct sk_buff *skb;
-       int len = sizeof(struct sta_req_hdr) + sizeof(struct sta_rec_sec);
        int ret;
 
-       skb = mt7915_mcu_alloc_sta_req(dev, mvif, msta, len);
+       skb = mt76_connac_mcu_alloc_sta_req(&dev->mt76, &mvif->mt76,
+                                           &msta->wcid);
        if (IS_ERR(skb))
                return PTR_ERR(skb);
 
@@ -1204,8 +1180,8 @@ mt7915_mcu_sta_ba(struct mt7915_dev *dev,
        if (enable && tx && !params->amsdu)
                msta->wcid.amsdu = false;
 
-       skb = mt7915_mcu_alloc_sta_req(dev, mvif, msta,
-                                      MT76_CONNAC_STA_UPDATE_MAX_SIZE);
+       skb = mt76_connac_mcu_alloc_sta_req(&dev->mt76, &mvif->mt76,
+                                           &msta->wcid);
        if (IS_ERR(skb))
                return PTR_ERR(skb);
 
@@ -1223,8 +1199,8 @@ mt7915_mcu_sta_ba(struct mt7915_dev *dev,
        if (ret)
                return ret;
 
-       skb = mt7915_mcu_alloc_sta_req(dev, mvif, msta,
-                                      MT76_CONNAC_STA_UPDATE_MAX_SIZE);
+       skb = mt76_connac_mcu_alloc_sta_req(&dev->mt76, &mvif->mt76,
+                                           &msta->wcid);
        if (IS_ERR(skb))
                return PTR_ERR(skb);
 
@@ -2050,9 +2026,9 @@ int mt7915_mcu_set_fixed_rate_ctrl(struct mt7915_dev *dev,
        struct sta_rec_ra_fixed *ra;
        struct sk_buff *skb;
        struct tlv *tlv;
-       int len = sizeof(struct sta_req_hdr) + sizeof(*ra);
 
-       skb = mt7915_mcu_alloc_sta_req(dev, mvif, msta, len);
+       skb = mt76_connac_mcu_alloc_sta_req(&dev->mt76, &mvif->mt76,
+                                           &msta->wcid);
        if (IS_ERR(skb))
                return PTR_ERR(skb);
 
@@ -2091,8 +2067,8 @@ int mt7915_mcu_add_smps(struct mt7915_dev *dev, struct ieee80211_vif *vif,
        struct sk_buff *skb;
        int ret;
 
-       skb = mt7915_mcu_alloc_sta_req(dev, mvif, msta,
-                                      MT76_CONNAC_STA_UPDATE_MAX_SIZE);
+       skb = mt76_connac_mcu_alloc_sta_req(&dev->mt76, &mvif->mt76,
+                                           &msta->wcid);
        if (IS_ERR(skb))
                return PTR_ERR(skb);
 
@@ -2304,8 +2280,8 @@ int mt7915_mcu_add_rate_ctrl(struct mt7915_dev *dev, struct ieee80211_vif *vif,
        struct sk_buff *skb;
        int ret;
 
-       skb = mt7915_mcu_alloc_sta_req(dev, mvif, msta,
-                                      MT76_CONNAC_STA_UPDATE_MAX_SIZE);
+       skb = mt76_connac_mcu_alloc_sta_req(&dev->mt76, &mvif->mt76,
+                                           &msta->wcid);
        if (IS_ERR(skb))
                return PTR_ERR(skb);
 
@@ -2371,8 +2347,8 @@ int mt7915_mcu_add_sta(struct mt7915_dev *dev, struct ieee80211_vif *vif,
 
        msta = sta ? (struct mt7915_sta *)sta->drv_priv : &mvif->sta;
 
-       skb = mt7915_mcu_alloc_sta_req(dev, mvif, msta,
-                                      MT76_CONNAC_STA_UPDATE_MAX_SIZE);
+       skb = mt76_connac_mcu_alloc_sta_req(&dev->mt76, &mvif->mt76,
+                                           &msta->wcid);
        if (IS_ERR(skb))
                return PTR_ERR(skb);
 
@@ -2602,7 +2578,8 @@ int mt7915_mcu_add_beacon(struct ieee80211_hw *hw,
        struct bss_info_bcn *bcn;
        int len = MT7915_BEACON_UPDATE_SIZE + MAX_BEACON_SIZE;
 
-       rskb = mt7915_mcu_alloc_sta_req(dev, mvif, NULL, len);
+       rskb = __mt76_connac_mcu_alloc_sta_req(&dev->mt76, &mvif->mt76,
+                                              NULL, len);
        if (IS_ERR(rskb))
                return PTR_ERR(rskb);
 
@@ -4263,7 +4240,8 @@ int mt7915_mcu_update_bss_color(struct mt7915_dev *dev, struct ieee80211_vif *vi
        struct sk_buff *skb;
        struct tlv *tlv;
 
-       skb = mt7915_mcu_alloc_sta_req(dev, mvif, NULL, len);
+       skb = __mt76_connac_mcu_alloc_sta_req(&dev->mt76, &mvif->mt76,
+                                             NULL, len);
        if (IS_ERR(skb))
                return PTR_ERR(skb);
 
index f1c4636540064ce0a6672072e5727d0e48ee999a..aeb9ef04ea4f53284421d2ce46b8304a29e8358f 100644 (file)
@@ -6,7 +6,7 @@
 
 #include <linux/interrupt.h>
 #include <linux/ktime.h>
-#include "../mt76.h"
+#include "../mt76_connac.h"
 #include "regs.h"
 
 #define MT7915_MAX_INTERFACES          19
@@ -479,11 +479,6 @@ int mt7915_mcu_fw_dbg_ctrl(struct mt7915_dev *dev, u32 module, u8 level);
 void mt7915_mcu_rx_event(struct mt7915_dev *dev, struct sk_buff *skb);
 void mt7915_mcu_exit(struct mt7915_dev *dev);
 
-static inline bool is_mt7915(struct mt76_dev *dev)
-{
-       return mt76_chip(dev) == 0x7915;
-}
-
 static inline u16 mt7915_wtbl_size(struct mt7915_dev *dev)
 {
        return is_mt7915(&dev->mt76) ? MT7915_WTBL_SIZE : MT7916_WTBL_SIZE;