blob: c72a0bb5f2ffe6d7f1cb19d52e1bc775393beb2e [file] [log] [blame]
developerfd40db22021-04-29 10:08:25 +08001// SPDX-License-Identifier: ISC
2/* Copyright (C) 2020 Felix Fietkau <nbd@nbd.name> */
developer175704f2021-06-22 17:33:53 +08003#ifndef __MT76_VENDOR_H
4#define __MT76_VENDOR_H
developerfd40db22021-04-29 10:08:25 +08005
developer175704f2021-06-22 17:33:53 +08006#include <errno.h>
7#include <linux/nl80211.h>
8#include <netlink/attr.h>
developerfd40db22021-04-29 10:08:25 +08009#include <stdbool.h>
10#include <stdint.h>
11#include <stdio.h>
developerfd40db22021-04-29 10:08:25 +080012#include <unl.h>
13
14typedef uint8_t u8;
15typedef uint16_t u16;
16typedef uint32_t u32;
17typedef uint64_t u64;
18typedef int8_t s8;
19typedef int16_t s16;
20typedef int32_t s32;
21typedef int64_t s64, ktime_t;
22
23#define MTK_NL80211_VENDOR_ID 0x0ce7
24
25#ifndef ARRAY_SIZE
26#define ARRAY_SIZE(a) (sizeof(a) / sizeof(a[0]))
27#endif
28
29#ifndef DIV_ROUND_UP
30#define DIV_ROUND_UP(n, d) (((n) + (d) - 1) / (d))
31#endif
32
33struct nl_msg;
34struct nlattr;
35
36enum mtk_nl80211_vendor_subcmds {
developere53f0872021-07-23 11:13:49 +080037 MTK_NL80211_VENDOR_SUBCMD_AMNT_CTRL = 0xae,
developerfd40db22021-04-29 10:08:25 +080038 MTK_NL80211_VENDOR_SUBCMD_CSI_CTRL = 0xc2,
developer5f18e6c2021-07-28 11:55:08 +080039 MTK_NL80211_VENDOR_SUBCMD_RFEATURE_CTRL = 0xc3,
40 MTK_NL80211_VENDOR_SUBCMD_WIRELESS_CTRL = 0xc4,
developer7f1a58f2022-05-26 16:00:32 -070041 MTK_NL80211_VENDOR_SUBCMD_HEMU_CTRL = 0xc5,
developerfd40db22021-04-29 10:08:25 +080042};
43
44enum mtk_vendor_attr_csi_ctrl {
45 MTK_VENDOR_ATTR_CSI_CTRL_UNSPEC,
46
47 MTK_VENDOR_ATTR_CSI_CTRL_CFG,
48 MTK_VENDOR_ATTR_CSI_CTRL_CFG_MODE,
49 MTK_VENDOR_ATTR_CSI_CTRL_CFG_TYPE,
50 MTK_VENDOR_ATTR_CSI_CTRL_CFG_VAL1,
51 MTK_VENDOR_ATTR_CSI_CTRL_CFG_VAL2,
52 MTK_VENDOR_ATTR_CSI_CTRL_MAC_ADDR,
developer175704f2021-06-22 17:33:53 +080053 MTK_VENDOR_ATTR_CSI_CTRL_INTERVAL,
developerfd40db22021-04-29 10:08:25 +080054
55 MTK_VENDOR_ATTR_CSI_CTRL_DUMP_NUM,
56
57 MTK_VENDOR_ATTR_CSI_CTRL_DATA,
58
59 /* keep last */
60 NUM_MTK_VENDOR_ATTRS_CSI_CTRL,
61 MTK_VENDOR_ATTR_CSI_CTRL_MAX =
62 NUM_MTK_VENDOR_ATTRS_CSI_CTRL - 1
63};
64
65enum mtk_vendor_attr_csi_data {
66 MTK_VENDOR_ATTR_CSI_DATA_UNSPEC,
67 MTK_VENDOR_ATTR_CSI_DATA_PAD,
68
69 MTK_VENDOR_ATTR_CSI_DATA_VER,
70 MTK_VENDOR_ATTR_CSI_DATA_TS,
71 MTK_VENDOR_ATTR_CSI_DATA_RSSI,
72 MTK_VENDOR_ATTR_CSI_DATA_SNR,
73 MTK_VENDOR_ATTR_CSI_DATA_BW,
74 MTK_VENDOR_ATTR_CSI_DATA_CH_IDX,
75 MTK_VENDOR_ATTR_CSI_DATA_TA,
76 MTK_VENDOR_ATTR_CSI_DATA_I,
77 MTK_VENDOR_ATTR_CSI_DATA_Q,
78 MTK_VENDOR_ATTR_CSI_DATA_INFO,
79 MTK_VENDOR_ATTR_CSI_DATA_RSVD1,
80 MTK_VENDOR_ATTR_CSI_DATA_RSVD2,
81 MTK_VENDOR_ATTR_CSI_DATA_RSVD3,
82 MTK_VENDOR_ATTR_CSI_DATA_RSVD4,
83 MTK_VENDOR_ATTR_CSI_DATA_TX_ANT,
84 MTK_VENDOR_ATTR_CSI_DATA_RX_ANT,
85 MTK_VENDOR_ATTR_CSI_DATA_MODE,
86 MTK_VENDOR_ATTR_CSI_DATA_H_IDX,
87
88 /* keep last */
89 NUM_MTK_VENDOR_ATTRS_CSI_DATA,
90 MTK_VENDOR_ATTR_CSI_DATA_MAX =
91 NUM_MTK_VENDOR_ATTRS_CSI_DATA - 1
92};
93
developere53f0872021-07-23 11:13:49 +080094enum mtk_vendor_attr_mnt_ctrl {
95 MTK_VENDOR_ATTR_AMNT_CTRL_UNSPEC,
96
97 MTK_VENDOR_ATTR_AMNT_CTRL_SET,
98 MTK_VENDOR_ATTR_AMNT_CTRL_DUMP,
99 /* keep last */
100 NUM_MTK_VENDOR_ATTRS_AMNT_CTRL,
101 MTK_VENDOR_ATTR_AMNT_CTRL_MAX =
102 NUM_MTK_VENDOR_ATTRS_AMNT_CTRL - 1
103};
104
105enum mtk_vendor_attr_mnt_set {
106 MTK_VENDOR_ATTR_AMNT_SET_UNSPEC,
107
108 MTK_VENDOR_ATTR_AMNT_SET_INDEX,
109 MTK_VENDOR_ATTR_AMNT_SET_MACADDR,
110
111 /* keep last */
112 NUM_MTK_VENDOR_ATTRS_AMNT_SET,
113 MTK_VENDOR_ATTR_AMNT_SET_MAX =
114 NUM_MTK_VENDOR_ATTRS_AMNT_SET - 1
115};
116
117enum mtk_vendor_attr_mnt_dump {
118 MTK_VENDOR_ATTR_AMNT_DUMP_UNSPEC,
119
120 MTK_VENDOR_ATTR_AMNT_DUMP_INDEX,
121 MTK_VENDOR_ATTR_AMNT_DUMP_LEN,
122 MTK_VENDOR_ATTR_AMNT_DUMP_RESULT,
123
124 /* keep last */
125 NUM_MTK_VENDOR_ATTRS_AMNT_DUMP,
126 MTK_VENDOR_ATTR_AMNT_DUMP_MAX =
127 NUM_MTK_VENDOR_ATTRS_AMNT_DUMP - 1
128};
129
developer5f18e6c2021-07-28 11:55:08 +0800130enum mtk_vendor_attr_wireless_ctrl {
131 MTK_VENDOR_ATTR_WIRELESS_CTRL_UNSPEC,
132
133 MTK_VENDOR_ATTR_WIRELESS_CTRL_FIXED_MCS,
developer507ff0c2021-07-30 14:51:55 +0800134 MTK_VENDOR_ATTR_WIRELESS_CTRL_FIXED_OFDMA,
developerb72be592021-08-16 10:58:59 +0800135 MTK_VENDOR_ATTR_WIRELESS_CTRL_PPDU_TX_TYPE,
136 MTK_VENDOR_ATTR_WIRELESS_CTRL_NUSERS_OFDMA,
developer786d9292021-09-22 11:03:21 +0800137 MTK_VENDOR_ATTR_WIRELESS_CTRL_BA_BUFFER_SIZE,
138 MTK_VENDOR_ATTR_WIRELESS_CTRL_MIMO,
developer3a5765c2021-09-23 16:19:12 +0800139 MTK_VENDOR_ATTR_WIRELESS_CTRL_AMPDU,
140 MTK_VENDOR_ATTR_WIRELESS_CTRL_AMSDU,
developer07ede8d2021-11-16 18:31:21 +0800141 MTK_VENDOR_ATTR_WIRELESS_CTRL_CERT,
developer5f18e6c2021-07-28 11:55:08 +0800142
143 /* keep last */
144 NUM_MTK_VENDOR_ATTRS_WIRELESS_CTRL,
145 MTK_VENDOR_ATTR_WIRELESS_CTRL_MAX =
146 NUM_MTK_VENDOR_ATTRS_WIRELESS_CTRL - 1
147};
148
developer7f1a58f2022-05-26 16:00:32 -0700149enum mtk_vendor_attr_hemu_ctrl {
150 MTK_VENDOR_ATTR_HEMU_CTRL_UNSPEC,
151
152 MTK_VENDOR_ATTR_HEMU_CTRL_ONOFF,
153
154 /* keep last */
155 NUM_MTK_VENDOR_ATTRS_HEMU_CTRL,
156 MTK_VENDOR_ATTR_HEMU_CTRL_MAX =
157 NUM_MTK_VENDOR_ATTRS_HEMU_CTRL - 1
158};
159
developer5f18e6c2021-07-28 11:55:08 +0800160enum mtk_vendor_attr_rfeature_ctrl {
161 MTK_VENDOR_ATTR_RFEATURE_CTRL_UNSPEC,
162
163 MTK_VENDOR_ATTR_RFEATURE_CTRL_HE_GI,
164 MTK_VENDOR_ATTR_RFEATURE_CTRL_HE_LTF,
developer13aaa772021-09-27 18:09:26 +0800165 MTK_VENDOR_ATTR_RFEATURE_CTRL_TRIG_TYPE_CFG,
166 MTK_VENDOR_ATTR_RFEATURE_CTRL_TRIG_TYPE_EN,
developer31b1a282021-08-04 14:13:00 +0800167 MTK_VENDOR_ATTR_RFEATURE_CTRL_TRIG_TYPE,
168 MTK_VENDOR_ATTR_RFEATURE_CTRL_ACK_PLCY,
developer5f18e6c2021-07-28 11:55:08 +0800169
170 /* keep last */
171 NUM_MTK_VENDOR_ATTRS_RFEATURE_CTRL,
172 MTK_VENDOR_ATTR_RFEATURE_CTRL_MAX =
173 NUM_MTK_VENDOR_ATTRS_RFEATURE_CTRL - 1
174};
175
developerfd40db22021-04-29 10:08:25 +0800176#define CSI_MAX_COUNT 256
177#define ETH_ALEN 6
178
179struct csi_data {
180 s16 data_i[CSI_MAX_COUNT];
181 s16 data_q[CSI_MAX_COUNT];
182 s8 rssi;
183 u8 snr;
developera1e20de2021-06-17 10:33:53 +0800184 u32 ts;
developerfd40db22021-04-29 10:08:25 +0800185 u8 data_bw;
186 u8 pri_ch_idx;
187 u8 ta[ETH_ALEN];
188 u32 info;
189 u8 rx_mode;
190 u32 h_idx;
191 u16 tx_idx;
192 u16 rx_idx;
193};
194
developere53f0872021-07-23 11:13:49 +0800195struct amnt_data {
196 u8 idx;
197 u8 addr[ETH_ALEN];
198 s8 rssi[4];
199 u32 last_seen;
200};
201
developerfd40db22021-04-29 10:08:25 +0800202extern struct unl unl;
developerfd40db22021-04-29 10:08:25 +0800203
developer175704f2021-06-22 17:33:53 +0800204int mt76_csi_set(int idx, int argc, char **argv);
205int mt76_csi_dump(int idx, int argc, char **argv);
developerfd40db22021-04-29 10:08:25 +0800206
developere53f0872021-07-23 11:13:49 +0800207int mt76_amnt_set(int idx, int argc, char **argv);
208int mt76_amnt_dump(int idx, int argc, char **argv);
209
developer5f18e6c2021-07-28 11:55:08 +0800210int mt76_ap_rfeatures_set(int idx, int argc, char **argv);
211int mt76_ap_wireless_set(int idx, int argc, char **argv);
developer7f1a58f2022-05-26 16:00:32 -0700212
213int mt76_hemu_onoff_set(int idx, int argc, char **argv);
developerfd40db22021-04-29 10:08:25 +0800214#endif