blob: 39d4df835cac08b0b78523087b45286d485e876d [file] [log] [blame]
developer4f0d84b2023-03-03 14:21:44 +08001From b789f416faea7dc90e4c83119274c773d417069c Mon Sep 17 00:00:00 2001
developerf64861f2022-06-22 11:44:53 +08002From: MeiChia Chiu <meichia.chiu@mediatek.com>
3Date: Wed, 22 Jun 2022 10:53:43 +0800
developer9851a292022-12-15 17:33:43 +08004Subject: [PATCH 1007/1009] mt76: mt7915: add mt76 vendor muru onoff command
developerf64861f2022-06-22 11:44:53 +08005
6---
developer5ce5ea42022-08-31 14:12:29 +08007 mt7915/mcu.c | 7 +++++++
8 mt7915/mcu.h | 1 +
9 mt7915/vendor.c | 43 +++++++++++++++++++++++++++++++++++++++++++
10 mt7915/vendor.h | 12 ++++++++++++
developerf64861f2022-06-22 11:44:53 +080011 4 files changed, 63 insertions(+)
12
developer7f1a58f2022-05-26 16:00:32 -070013diff --git a/mt7915/mcu.c b/mt7915/mcu.c
developer4f0d84b2023-03-03 14:21:44 +080014index 03c94349..70349a75 100644
developer7f1a58f2022-05-26 16:00:32 -070015--- a/mt7915/mcu.c
16+++ b/mt7915/mcu.c
developer4f0d84b2023-03-03 14:21:44 +080017@@ -3960,6 +3960,13 @@ void mt7915_set_wireless_vif(void *data, u8 *mac, struct ieee80211_vif *vif)
developer7f1a58f2022-05-26 16:00:32 -070018 if (val == 0)
developereb2bd8e2023-02-09 11:16:04 +080019 phy->muru_onoff = MUMIMO_DL_CERT | MUMIMO_DL;
developer7f1a58f2022-05-26 16:00:32 -070020 break;
developer57de9b72023-02-20 11:15:54 +080021+ case RATE_PARAM_AUTO_MU:
developer7f1a58f2022-05-26 16:00:32 -070022+ if (val < 0 || val > 15) {
23+ printk("Wrong value! The value is between 0-15.\n");
24+ break;
25+ }
developereb2bd8e2023-02-09 11:16:04 +080026+ phy->muru_onoff = val;
developer7f1a58f2022-05-26 16:00:32 -070027+ break;
28 }
29 }
30
31diff --git a/mt7915/mcu.h b/mt7915/mcu.h
developer4f0d84b2023-03-03 14:21:44 +080032index 714bc44d..ac4e6c8b 100644
developer7f1a58f2022-05-26 16:00:32 -070033--- a/mt7915/mcu.h
34+++ b/mt7915/mcu.h
developerc04f5402023-02-03 09:22:26 +080035@@ -423,6 +423,7 @@ enum {
developer7f1a58f2022-05-26 16:00:32 -070036 #ifdef CONFIG_MTK_VENDOR
37 RATE_PARAM_FIXED_MIMO = 30,
38 RATE_PARAM_FIXED_OFDMA = 31,
developer57de9b72023-02-20 11:15:54 +080039+ RATE_PARAM_AUTO_MU = 32,
developer7f1a58f2022-05-26 16:00:32 -070040 #endif
41 };
42
43diff --git a/mt7915/vendor.c b/mt7915/vendor.c
developer4f0d84b2023-03-03 14:21:44 +080044index beb0583a..8d864c86 100644
developer7f1a58f2022-05-26 16:00:32 -070045--- a/mt7915/vendor.c
46+++ b/mt7915/vendor.c
47@@ -34,6 +34,11 @@ wireless_ctrl_policy[NUM_MTK_VENDOR_ATTRS_WIRELESS_CTRL] = {
48 [MTK_VENDOR_ATTR_WIRELESS_CTRL_CERT] = {.type = NLA_U8 },
49 };
50
51+static const struct nla_policy
developer57de9b72023-02-20 11:15:54 +080052+mu_ctrl_policy[NUM_MTK_VENDOR_ATTRS_MU_CTRL] = {
53+ [MTK_VENDOR_ATTR_MU_CTRL_ONOFF] = {.type = NLA_U8 },
developer7f1a58f2022-05-26 16:00:32 -070054+};
55+
56 static const struct nla_policy
57 rfeature_ctrl_policy[NUM_MTK_VENDOR_ATTRS_RFEATURE_CTRL] = {
58 [MTK_VENDOR_ATTR_RFEATURE_CTRL_HE_GI] = {.type = NLA_U8 },
developerf64861f2022-06-22 11:44:53 +080059@@ -942,6 +947,33 @@ static int mt7915_vendor_wireless_ctrl(struct wiphy *wiphy,
developer7f1a58f2022-05-26 16:00:32 -070060 return 0;
61 }
62
developer57de9b72023-02-20 11:15:54 +080063+static int mt7915_vendor_mu_ctrl(struct wiphy *wiphy,
developer7f1a58f2022-05-26 16:00:32 -070064+ struct wireless_dev *wdev,
65+ const void *data,
66+ int data_len)
67+{
68+ struct ieee80211_hw *hw = wiphy_to_ieee80211_hw(wiphy);
developer57de9b72023-02-20 11:15:54 +080069+ struct nlattr *tb[NUM_MTK_VENDOR_ATTRS_MU_CTRL];
developer7f1a58f2022-05-26 16:00:32 -070070+ int err;
71+ u8 val8;
72+ u32 val32 = 0;
73+
developer57de9b72023-02-20 11:15:54 +080074+ err = nla_parse(tb, MTK_VENDOR_ATTR_MU_CTRL_MAX, data, data_len,
75+ mu_ctrl_policy, NULL);
developer7f1a58f2022-05-26 16:00:32 -070076+ if (err)
77+ return err;
78+
developer57de9b72023-02-20 11:15:54 +080079+ if (tb[MTK_VENDOR_ATTR_MU_CTRL_ONOFF]) {
80+ val8 = nla_get_u8(tb[MTK_VENDOR_ATTR_MU_CTRL_ONOFF]);
81+ val32 |= FIELD_PREP(RATE_CFG_MODE, RATE_PARAM_AUTO_MU) |
developer7f1a58f2022-05-26 16:00:32 -070082+ FIELD_PREP(RATE_CFG_VAL, val8);
83+ ieee80211_iterate_active_interfaces_atomic(hw, IEEE80211_IFACE_ITER_RESUME_ALL,
84+ mt7915_set_wireless_vif, &val32);
85+ }
86+
87+ return 0;
88+}
89+
90 static const struct wiphy_vendor_command mt7915_vendor_commands[] = {
91 {
92 .info = {
developerf64861f2022-06-22 11:44:53 +080093@@ -988,6 +1020,17 @@ static const struct wiphy_vendor_command mt7915_vendor_commands[] = {
developer7f1a58f2022-05-26 16:00:32 -070094 .doit = mt7915_vendor_wireless_ctrl,
95 .policy = wireless_ctrl_policy,
96 .maxattr = MTK_VENDOR_ATTR_WIRELESS_CTRL_MAX,
97+ },
98+ {
99+ .info = {
100+ .vendor_id = MTK_NL80211_VENDOR_ID,
developer57de9b72023-02-20 11:15:54 +0800101+ .subcmd = MTK_NL80211_VENDOR_SUBCMD_MU_CTRL,
developer7f1a58f2022-05-26 16:00:32 -0700102+ },
103+ .flags = WIPHY_VENDOR_CMD_NEED_NETDEV |
104+ WIPHY_VENDOR_CMD_NEED_RUNNING,
developer57de9b72023-02-20 11:15:54 +0800105+ .doit = mt7915_vendor_mu_ctrl,
106+ .policy = mu_ctrl_policy,
107+ .maxattr = MTK_VENDOR_ATTR_MU_CTRL_MAX,
developer7f1a58f2022-05-26 16:00:32 -0700108 }
109 };
110
111diff --git a/mt7915/vendor.h b/mt7915/vendor.h
developer4f0d84b2023-03-03 14:21:44 +0800112index 1b08321c..2be5fc89 100644
developer7f1a58f2022-05-26 16:00:32 -0700113--- a/mt7915/vendor.h
114+++ b/mt7915/vendor.h
115@@ -8,6 +8,7 @@ enum mtk_nl80211_vendor_subcmds {
116 MTK_NL80211_VENDOR_SUBCMD_CSI_CTRL = 0xc2,
117 MTK_NL80211_VENDOR_SUBCMD_RFEATURE_CTRL = 0xc3,
118 MTK_NL80211_VENDOR_SUBCMD_WIRELESS_CTRL = 0xc4,
developer57de9b72023-02-20 11:15:54 +0800119+ MTK_NL80211_VENDOR_SUBCMD_MU_CTRL = 0xc5,
developer7f1a58f2022-05-26 16:00:32 -0700120 };
121
122 enum mtk_capi_control_changed {
123@@ -33,6 +34,17 @@ enum mtk_vendor_attr_wireless_ctrl {
124 NUM_MTK_VENDOR_ATTRS_WIRELESS_CTRL - 1
125 };
126
developer57de9b72023-02-20 11:15:54 +0800127+enum mtk_vendor_attr_mu_ctrl {
128+ MTK_VENDOR_ATTR_MU_CTRL_UNSPEC,
developer7f1a58f2022-05-26 16:00:32 -0700129+
developer57de9b72023-02-20 11:15:54 +0800130+ MTK_VENDOR_ATTR_MU_CTRL_ONOFF,
developer7f1a58f2022-05-26 16:00:32 -0700131+
132+ /* keep last */
developer57de9b72023-02-20 11:15:54 +0800133+ NUM_MTK_VENDOR_ATTRS_MU_CTRL,
134+ MTK_VENDOR_ATTR_MU_CTRL_MAX =
135+ NUM_MTK_VENDOR_ATTRS_MU_CTRL - 1
developer7f1a58f2022-05-26 16:00:32 -0700136+};
137+
138 enum mtk_vendor_attr_rfeature_ctrl {
139 MTK_VENDOR_ATTR_RFEATURE_CTRL_UNSPEC,
140
developerf64861f2022-06-22 11:44:53 +0800141--
developer4f0d84b2023-03-03 14:21:44 +08001422.18.0
developerf64861f2022-06-22 11:44:53 +0800143