blob: 0fcde9da4e6adf6d056d0c462af8738275fcdb5c [file] [log] [blame]
developerd8126d12023-02-17 11:50:45 +08001From dc1ea53db698073c61765925cdb17d28043c6f2d Mon Sep 17 00:00:00 2001
developere2cfb522022-12-08 18:09:45 +08002From: TomLiu <tomml.liu@mediatek.com>
3Date: Thu, 11 Aug 2022 18:09:45 -0700
developer60a3d662023-02-07 15:24:34 +08004Subject: [PATCH 1124/1133] mt76: mt7915: Add hemu dump support
developere2cfb522022-12-08 18:09:45 +08005
6Change-Id: I521214f3feb6f0d528a9f550255050ffd1ec96d2
7---
developer4d581862023-02-13 16:01:56 +08008 mt7915/vendor.c | 24 ++++++++++++++++++++++++
developere2cfb522022-12-08 18:09:45 +08009 mt7915/vendor.h | 1 +
developer4d581862023-02-13 16:01:56 +080010 2 files changed, 25 insertions(+)
developere2cfb522022-12-08 18:09:45 +080011
12diff --git a/mt7915/vendor.c b/mt7915/vendor.c
developerd8126d12023-02-17 11:50:45 +080013index f712d67c..83f38e07 100644
developere2cfb522022-12-08 18:09:45 +080014--- a/mt7915/vendor.c
15+++ b/mt7915/vendor.c
16@@ -37,6 +37,7 @@ wireless_ctrl_policy[NUM_MTK_VENDOR_ATTRS_WIRELESS_CTRL] = {
17 static const struct nla_policy
18 hemu_ctrl_policy[NUM_MTK_VENDOR_ATTRS_HEMU_CTRL] = {
19 [MTK_VENDOR_ATTR_HEMU_CTRL_ONOFF] = {.type = NLA_U8 },
20+ [MTK_VENDOR_ATTR_HEMU_CTRL_DUMP] = {.type = NLA_U8 },
21 };
22
23 static const struct nla_policy
developer4d581862023-02-13 16:01:56 +080024@@ -1004,6 +1005,28 @@ static int mt7915_vendor_hemu_ctrl(struct wiphy *wiphy,
developere2cfb522022-12-08 18:09:45 +080025 return 0;
26 }
27
28+
29+static int
30+mt7915_vendor_hemu_ctrl_dump(struct wiphy *wiphy, struct wireless_dev *wdev,
31+ struct sk_buff *skb, const void *data, int data_len,
32+ unsigned long *storage)
33+{
34+ struct ieee80211_hw *hw = wiphy_to_ieee80211_hw(wiphy);
35+ struct mt7915_phy *phy = mt7915_hw_phy(hw);
developere2cfb522022-12-08 18:09:45 +080036+ int len = 0;
37+
38+ if (*storage == 1)
39+ return -ENOENT;
40+ *storage = 1;
41+
developer4d581862023-02-13 16:01:56 +080042+ if (nla_put_u8(skb, MTK_VENDOR_ATTR_HEMU_CTRL_DUMP, phy->muru_onoff))
developere2cfb522022-12-08 18:09:45 +080043+ return -ENOMEM;
44+ len += 1;
45+
46+ return len;
47+}
48+
49+
50 static int
51 mt7915_vendor_phy_capa_ctrl_dump(struct wiphy *wiphy, struct wireless_dev *wdev,
52 struct sk_buff *skb, const void *data, int data_len,
developer4d581862023-02-13 16:01:56 +080053@@ -1190,6 +1213,7 @@ static const struct wiphy_vendor_command mt7915_vendor_commands[] = {
developere2cfb522022-12-08 18:09:45 +080054 .flags = WIPHY_VENDOR_CMD_NEED_NETDEV |
55 WIPHY_VENDOR_CMD_NEED_RUNNING,
56 .doit = mt7915_vendor_hemu_ctrl,
57+ .dumpit = mt7915_vendor_hemu_ctrl_dump,
58 .policy = hemu_ctrl_policy,
59 .maxattr = MTK_VENDOR_ATTR_HEMU_CTRL_MAX,
60 },
61diff --git a/mt7915/vendor.h b/mt7915/vendor.h
developerd8126d12023-02-17 11:50:45 +080062index 72319717..c19ffe72 100644
developere2cfb522022-12-08 18:09:45 +080063--- a/mt7915/vendor.h
64+++ b/mt7915/vendor.h
65@@ -72,6 +72,7 @@ enum mtk_vendor_attr_hemu_ctrl {
66 MTK_VENDOR_ATTR_HEMU_CTRL_UNSPEC,
67
68 MTK_VENDOR_ATTR_HEMU_CTRL_ONOFF,
69+ MTK_VENDOR_ATTR_HEMU_CTRL_DUMP,
70
71 /* keep last */
72 NUM_MTK_VENDOR_ATTRS_HEMU_CTRL,
73--
developerd8126d12023-02-17 11:50:45 +0800742.18.0
developere2cfb522022-12-08 18:09:45 +080075