blob: 61286240bd853db0154b1873a975af15285a1199 [file] [log] [blame]
developerefb40c12022-12-21 18:05:47 +08001From 413d06c543e77b9d0acf7e75819a62a068a5359e 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
developer2aa1e642022-12-19 11:33:22 +08004Subject: [PATCH 1129/1131] mt76: mt7915: support on off SW ACI through debugfs
developer6a1998b2022-12-08 18:09:45 +08005
6Signed-off-by: Evelyn Tsai <evelyn.tsai@mediatek.com>
7Change-Id: I8a9c277c41d1ba76f9737d8af6f42e5e8f00ba64
8---
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
developer2aa1e642022-12-19 11:33:22 +080014index 5cff1a4..98b0074 100644
developer6a1998b2022-12-08 18:09:45 +080015--- a/mt76_connac_mcu.h
16+++ b/mt76_connac_mcu.h
developer79e690d2022-12-13 17:05:25 +080017@@ -1201,6 +1201,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
developer2aa1e642022-12-19 11:33:22 +080026index 7567666..19cc8cb 100644
developer6a1998b2022-12-08 18:09:45 +080027--- a/mt7915/mtk_debugfs.c
28+++ b/mt7915/mtk_debugfs.c
developer2aa1e642022-12-19 11:33:22 +080029@@ -2963,6 +2963,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;
developer2aa1e642022-12-19 11:33:22 +080055@@ -3050,6 +3069,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--
developer2aa1e642022-12-19 11:33:22 +0800652.36.1
developer6a1998b2022-12-08 18:09:45 +080066