blob: de8c46e1fd80d50cdd5d5ab308086aa18045eb2d [file] [log] [blame]
From ab4e26243d8bbccfe1e8ba69c1af4e3457909f32 Mon Sep 17 00:00:00 2001
From: Shayne Chen <shayne.chen@mediatek.com>
Date: Thu, 21 Sep 2023 00:52:46 +0800
Subject: [PATCH 1024/1044] mtk: wifi: mt76: mt7996: support dup wtbl
Signed-off-by: Shayne Chen <shayne.chen@mediatek.com>
---
mt7996/init.c | 1 +
mt7996/mt7996.h | 1 +
mt7996/mtk_mcu.c | 23 +++++++++++++++++++++++
3 files changed, 25 insertions(+)
diff --git a/mt7996/init.c b/mt7996/init.c
index 1498787f..30879ec3 100644
--- a/mt7996/init.c
+++ b/mt7996/init.c
@@ -675,6 +675,7 @@ static void mt7996_init_work(struct work_struct *work)
mt7996_mcu_set_eeprom(dev);
mt7996_mac_init(dev);
mt7996_txbf_init(dev);
+ mt7996_mcu_set_dup_wtbl(dev);
}
void mt7996_wfsys_reset(struct mt7996_dev *dev)
diff --git a/mt7996/mt7996.h b/mt7996/mt7996.h
index b2fb68c3..23497b46 100644
--- a/mt7996/mt7996.h
+++ b/mt7996/mt7996.h
@@ -807,6 +807,7 @@ int mt7996_mtk_init_debugfs(struct mt7996_phy *phy, struct dentry *dir);
int mt7996_mcu_muru_dbg_info(struct mt7996_dev *dev, u16 item, u8 val);
int mt7996_mcu_set_sr_enable(struct mt7996_phy *phy, u8 action, u64 val, bool set);
void mt7996_mcu_rx_sr_event(struct mt7996_dev *dev, struct sk_buff *skb);
+int mt7996_mcu_set_dup_wtbl(struct mt7996_dev *dev);
#endif
#ifdef CONFIG_NET_MEDIATEK_SOC_WED
diff --git a/mt7996/mtk_mcu.c b/mt7996/mtk_mcu.c
index dbdf8d80..ea4e5bf2 100644
--- a/mt7996/mtk_mcu.c
+++ b/mt7996/mtk_mcu.c
@@ -257,4 +257,27 @@ void mt7996_mcu_rx_sr_event(struct mt7996_dev *dev, struct sk_buff *skb)
le16_to_cpu(event->basic.tag));
}
}
+
+int mt7996_mcu_set_dup_wtbl(struct mt7996_dev *dev)
+{
+#define CHIP_CONFIG_DUP_WTBL 4
+#define DUP_WTBL_NUM 80
+ struct {
+ u8 _rsv[4];
+
+ __le16 tag;
+ __le16 len;
+ __le16 base;
+ __le16 num;
+ u8 _rsv2[4];
+ } __packed req = {
+ .tag = cpu_to_le16(CHIP_CONFIG_DUP_WTBL),
+ .len = cpu_to_le16(sizeof(req) - 4),
+ .base = cpu_to_le16(MT7996_WTBL_STA - DUP_WTBL_NUM + 1),
+ .num = cpu_to_le16(DUP_WTBL_NUM),
+ };
+
+ return mt76_mcu_send_msg(&dev->mt76, MCU_WM_UNI_CMD(CHIP_CONFIG), &req,
+ sizeof(req), true);
+}
#endif
--
2.18.0