wifi: mt76: move mt76_net_setup_tc in common code
authorLorenzo Bianconi <lorenzo@kernel.org>
Fri, 20 Oct 2023 10:30:50 +0000 (12:30 +0200)
committerFelix Fietkau <nbd@nbd.name>
Thu, 7 Dec 2023 17:50:20 +0000 (18:50 +0100)
This is a preliminary patch to introduce WED support for mt7996

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

index 81746d4cd4c8be18268410229db87818ee34e84f..b0dbea964c296b453539c2f287edc0369cb7aca0 100644 (file)
@@ -1853,3 +1853,19 @@ enum mt76_dfs_state mt76_phy_dfs_state(struct mt76_phy *phy)
        return MT_DFS_STATE_ACTIVE;
 }
 EXPORT_SYMBOL_GPL(mt76_phy_dfs_state);
+
+#ifdef CONFIG_NET_MEDIATEK_SOC_WED
+int mt76_net_setup_tc(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
+                     struct net_device *netdev, enum tc_setup_type type,
+                     void *type_data)
+{
+       struct mt76_phy *phy = hw->priv;
+       struct mtk_wed_device *wed = &phy->dev->mmio.wed;
+
+       if (!mtk_wed_device_active(wed))
+               return -EOPNOTSUPP;
+
+       return mtk_wed_device_setup_tc(wed, netdev, type, type_data);
+}
+EXPORT_SYMBOL_GPL(mt76_net_setup_tc);
+#endif /* CONFIG_NET_MEDIATEK_SOC_WED */
index a1809a6ea8daaafae9b5f33c8932e6c625f92928..9035db4129a99be4f16be674facf68b574dc5728 100644 (file)
@@ -1047,6 +1047,12 @@ bool ____mt76_poll_msec(struct mt76_dev *dev, u32 offset, u32 mask, u32 val,
 void mt76_mmio_init(struct mt76_dev *dev, void __iomem *regs);
 void mt76_pci_disable_aspm(struct pci_dev *pdev);
 
+#ifdef CONFIG_NET_MEDIATEK_SOC_WED
+int mt76_net_setup_tc(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
+                     struct net_device *netdev, enum tc_setup_type type,
+                     void *type_data);
+#endif /*CONFIG_NET_MEDIATEK_SOC_WED */
+
 static inline u16 mt76_chip(struct mt76_dev *dev)
 {
        return dev->rev >> 16;
index a3fd54cc1911afb1eb22ffd7a9e5a8515b6cc834..ba34c8e19aabf274cfeec642d31754d7589ba436 100644 (file)
@@ -1653,20 +1653,6 @@ mt7915_net_fill_forward_path(struct ieee80211_hw *hw,
 
        return 0;
 }
-
-static int
-mt7915_net_setup_tc(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
-                   struct net_device *netdev, enum tc_setup_type type,
-                   void *type_data)
-{
-       struct mt7915_dev *dev = mt7915_hw_dev(hw);
-       struct mtk_wed_device *wed = &dev->mt76.mmio.wed;
-
-       if (!mtk_wed_device_active(wed))
-               return -EOPNOTSUPP;
-
-       return mtk_wed_device_setup_tc(wed, netdev, type, type_data);
-}
 #endif
 
 const struct ieee80211_ops mt7915_ops = {
@@ -1721,6 +1707,6 @@ const struct ieee80211_ops mt7915_ops = {
        .set_radar_background = mt7915_set_radar_background,
 #ifdef CONFIG_NET_MEDIATEK_SOC_WED
        .net_fill_forward_path = mt7915_net_fill_forward_path,
-       .net_setup_tc = mt7915_net_setup_tc,
+       .net_setup_tc = mt76_net_setup_tc,
 #endif
 };