blob: 3d5a3e7732a2ce128b9c81acfa823ad2d075cff1 [file] [log] [blame]
developer43a264f2024-03-26 14:09:54 +08001From e769bcee5b7268643d5be9fab858ec46c8bc7584 Mon Sep 17 00:00:00 2001
developer6a1998b2022-12-08 18:09:45 +08002From: Evelyn Tsai <evelyn.tsai@mediatek.com>
3Date: Fri, 14 Oct 2022 11:15:13 +0800
developer43a264f2024-03-26 14:09:54 +08004Subject: [PATCH 1021/1051] wifi: mt76: mt7915: support on off SW ACI through
developer78848c62023-04-06 13:44:00 +08005 debugfs
developer6a1998b2022-12-08 18:09:45 +08006
7Signed-off-by: Evelyn Tsai <evelyn.tsai@mediatek.com>
developer6a1998b2022-12-08 18:09:45 +08008---
9 mt76_connac_mcu.h | 1 +
10 mt7915/mtk_debugfs.c | 21 +++++++++++++++++++++
11 2 files changed, 22 insertions(+)
12
13diff --git a/mt76_connac_mcu.h b/mt76_connac_mcu.h
developer43a264f2024-03-26 14:09:54 +080014index 6f6a889b..12654017 100644
developer6a1998b2022-12-08 18:09:45 +080015--- a/mt76_connac_mcu.h
16+++ b/mt76_connac_mcu.h
developerebda9012024-02-22 13:42:45 +080017@@ -1244,6 +1244,7 @@ enum {
developer6a1998b2022-12-08 18:09:45 +080018 MCU_EXT_CMD_RX_STAT_USER_CTRL = 0xb3,
19 MCU_EXT_CMD_SET_CFG = 0xb7,
20 MCU_EXT_CMD_EDCCA = 0xba,
21+ MCU_EXT_CMD_SWLNA_ACI_CTRL = 0xc0,
22 MCU_EXT_CMD_CSI_CTRL = 0xc2,
23 MCU_EXT_CMD_IPI_HIST_SCAN = 0xc5,
24 };
25diff --git a/mt7915/mtk_debugfs.c b/mt7915/mtk_debugfs.c
developer43a264f2024-03-26 14:09:54 +080026index 9270a5e5..e8296476 100644
developer6a1998b2022-12-08 18:09:45 +080027--- a/mt7915/mtk_debugfs.c
28+++ b/mt7915/mtk_debugfs.c
developer43a264f2024-03-26 14:09:54 +080029@@ -3770,6 +3770,25 @@ static int mt7915_show_eeprom_mode(struct seq_file *s, void *data)
developer6a1998b2022-12-08 18:09:45 +080030 return 0;
31 }
32
33+static int
34+mt7915_sw_aci_set(void *data, u64 val)
35+{
36+#define SWLNA_ENABLE 6
37+ struct mt7915_dev *dev = data;
38+ struct {
39+ u32 subcmd;
40+ u8 enable;
41+ } req = {
42+ .subcmd = SWLNA_ENABLE,
43+ .enable = (u8) val,
44+ };
45+ return mt76_mcu_send_msg(&dev->mt76, MCU_EXT_CMD(SWLNA_ACI_CTRL), &req, sizeof(req), NULL);
46+}
47+
48+
49+DEFINE_DEBUGFS_ATTRIBUTE(fops_sw_aci, NULL,
50+ mt7915_sw_aci_set, "%llx\n");
51+
52 int mt7915_mtk_init_debugfs(struct mt7915_phy *phy, struct dentry *dir)
53 {
54 struct mt7915_dev *dev = phy->dev;
developer43a264f2024-03-26 14:09:54 +080055@@ -3858,6 +3877,8 @@ int mt7915_mtk_init_debugfs(struct mt7915_phy *phy, struct dentry *dir)
developer6a1998b2022-12-08 18:09:45 +080056
57 debugfs_create_devm_seqfile(dev->mt76.dev, "eeprom_mode", dir,
58 mt7915_show_eeprom_mode);
59+ debugfs_create_file("sw_aci", 0600, dir, dev,
60+ &fops_sw_aci);
61 return 0;
62 }
63 #endif
64--
developere35b8e42023-10-16 11:04:00 +0800652.18.0
developer6a1998b2022-12-08 18:09:45 +080066