blob: 4536ed1556c120e7b09e08c99e4ea15f87a537c3 [file] [log] [blame]
developerb403ad02022-11-08 10:16:29 +08001From a6c223bb69c974e93d1c3793615d1e1937d159bf Mon Sep 17 00:00:00 2001
developerf10a8982022-10-17 12:01:44 +08002From: Evelyn Tsai <evelyn.tsai@mediatek.com>
3Date: Fri, 14 Oct 2022 11:15:13 +0800
developerb403ad02022-11-08 10:16:29 +08004Subject: [PATCH 1128/1128] mt76: support on off SW ACI through debugfs
developerf10a8982022-10-17 12:01:44 +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
developerb403ad02022-11-08 10:16:29 +080014index 9a57505..85bf978 100644
developerf10a8982022-10-17 12:01:44 +080015--- a/mt76_connac_mcu.h
16+++ b/mt76_connac_mcu.h
developerb403ad02022-11-08 10:16:29 +080017@@ -1159,6 +1159,7 @@ enum {
developerf10a8982022-10-17 12:01:44 +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,
developerb403ad02022-11-08 10:16:29 +080023 MCU_EXT_CMD_IPI_HIST_SCAN = 0xc5,
developerf10a8982022-10-17 12:01:44 +080024 };
developerf10a8982022-10-17 12:01:44 +080025diff --git a/mt7915/mtk_debugfs.c b/mt7915/mtk_debugfs.c
developerb403ad02022-11-08 10:16:29 +080026index 9de5b0f..c5e0472 100644
developerf10a8982022-10-17 12:01:44 +080027--- a/mt7915/mtk_debugfs.c
28+++ b/mt7915/mtk_debugfs.c
29@@ -2893,6 +2893,25 @@ mt7915_wa_debug(void *data, u64 val)
30 DEFINE_DEBUGFS_ATTRIBUTE(fops_wa_debug, NULL, mt7915_wa_debug,
31 "0x%llx\n");
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;
55@@ -2973,6 +2992,8 @@ int mt7915_mtk_init_debugfs(struct mt7915_phy *phy, struct dentry *dir)
56 debugfs_create_devm_seqfile(dev->mt76.dev, "fw_version", dir,
57 mt7915_dump_version);
58
59+ debugfs_create_file("sw_aci", 0600, dir, dev,
60+ &fops_sw_aci);
61 return 0;
62 }
63 #endif
64--
developerb403ad02022-11-08 10:16:29 +0800652.18.0
developerf10a8982022-10-17 12:01:44 +080066