blob: 998228bb20f65e9a149554004fbc583be5f51b5d [file] [log] [blame]
developer4f0d84b2023-03-03 14:21:44 +08001From 19ed70a278de504a58054906f9b25b4f5c3cf3d0 Mon Sep 17 00:00:00 2001
developer81ca9d62022-10-14 11:23:22 +08002From: Evelyn Tsai <evelyn.tsai@mediatek.com>
3Date: Fri, 14 Oct 2022 11:15:13 +0800
developer4f0d84b2023-03-03 14:21:44 +08004Subject: [PATCH 1128/1132] mt76: mt7915: support on off SW ACI through debugfs
developer81ca9d62022-10-14 11:23:22 +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
developer4f0d84b2023-03-03 14:21:44 +080014index 1ff517f0..1a13cee0 100644
developer81ca9d62022-10-14 11:23:22 +080015--- a/mt76_connac_mcu.h
16+++ b/mt76_connac_mcu.h
developer4f0d84b2023-03-03 14:21:44 +080017@@ -1203,6 +1203,7 @@ enum {
developer81ca9d62022-10-14 11:23:22 +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,
developer887da632022-10-28 09:35:38 +080023 MCU_EXT_CMD_IPI_HIST_SCAN = 0xc5,
developer81ca9d62022-10-14 11:23:22 +080024 };
developer81ca9d62022-10-14 11:23:22 +080025diff --git a/mt7915/mtk_debugfs.c b/mt7915/mtk_debugfs.c
developer4f0d84b2023-03-03 14:21:44 +080026index 1f347efe..224d9960 100644
developer81ca9d62022-10-14 11:23:22 +080027--- a/mt7915/mtk_debugfs.c
28+++ b/mt7915/mtk_debugfs.c
developerd75d3632023-01-05 14:31:01 +080029@@ -3040,6 +3040,25 @@ static int mt7915_show_eeprom_mode(struct seq_file *s, void *data)
developer29647af2022-11-15 18:09:16 +080030 return 0;
31 }
developer81ca9d62022-10-14 11:23:22 +080032
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;
developerd75d3632023-01-05 14:31:01 +080055@@ -3127,6 +3146,8 @@ int mt7915_mtk_init_debugfs(struct mt7915_phy *phy, struct dentry *dir)
developer81ca9d62022-10-14 11:23:22 +080056
developer29647af2022-11-15 18:09:16 +080057 debugfs_create_devm_seqfile(dev->mt76.dev, "eeprom_mode", dir,
58 mt7915_show_eeprom_mode);
developer81ca9d62022-10-14 11:23:22 +080059+ debugfs_create_file("sw_aci", 0600, dir, dev,
60+ &fops_sw_aci);
61 return 0;
62 }
63 #endif
64--
developerd75d3632023-01-05 14:31:01 +0800652.18.0
developer81ca9d62022-10-14 11:23:22 +080066