blob: 08d4c26788599d9bd197c4c8c99436fda9c18643 [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,
developerfd40db22021-04-29 10:08:25 +080041};
42
43enum mtk_vendor_attr_csi_ctrl {
44 MTK_VENDOR_ATTR_CSI_CTRL_UNSPEC,
45
46 MTK_VENDOR_ATTR_CSI_CTRL_CFG,
47 MTK_VENDOR_ATTR_CSI_CTRL_CFG_MODE,
48 MTK_VENDOR_ATTR_CSI_CTRL_CFG_TYPE,
49 MTK_VENDOR_ATTR_CSI_CTRL_CFG_VAL1,
50 MTK_VENDOR_ATTR_CSI_CTRL_CFG_VAL2,
51 MTK_VENDOR_ATTR_CSI_CTRL_MAC_ADDR,
developer175704f2021-06-22 17:33:53 +080052 MTK_VENDOR_ATTR_CSI_CTRL_INTERVAL,
developerfd40db22021-04-29 10:08:25 +080053
54 MTK_VENDOR_ATTR_CSI_CTRL_DUMP_NUM,
55
56 MTK_VENDOR_ATTR_CSI_CTRL_DATA,
57
58 /* keep last */
59 NUM_MTK_VENDOR_ATTRS_CSI_CTRL,
60 MTK_VENDOR_ATTR_CSI_CTRL_MAX =
61 NUM_MTK_VENDOR_ATTRS_CSI_CTRL - 1
62};
63
64enum mtk_vendor_attr_csi_data {
65 MTK_VENDOR_ATTR_CSI_DATA_UNSPEC,
66 MTK_VENDOR_ATTR_CSI_DATA_PAD,
67
68 MTK_VENDOR_ATTR_CSI_DATA_VER,
69 MTK_VENDOR_ATTR_CSI_DATA_TS,
70 MTK_VENDOR_ATTR_CSI_DATA_RSSI,
71 MTK_VENDOR_ATTR_CSI_DATA_SNR,
72 MTK_VENDOR_ATTR_CSI_DATA_BW,
73 MTK_VENDOR_ATTR_CSI_DATA_CH_IDX,
74 MTK_VENDOR_ATTR_CSI_DATA_TA,
75 MTK_VENDOR_ATTR_CSI_DATA_I,
76 MTK_VENDOR_ATTR_CSI_DATA_Q,
77 MTK_VENDOR_ATTR_CSI_DATA_INFO,
78 MTK_VENDOR_ATTR_CSI_DATA_RSVD1,
79 MTK_VENDOR_ATTR_CSI_DATA_RSVD2,
80 MTK_VENDOR_ATTR_CSI_DATA_RSVD3,
81 MTK_VENDOR_ATTR_CSI_DATA_RSVD4,
82 MTK_VENDOR_ATTR_CSI_DATA_TX_ANT,
83 MTK_VENDOR_ATTR_CSI_DATA_RX_ANT,
84 MTK_VENDOR_ATTR_CSI_DATA_MODE,
85 MTK_VENDOR_ATTR_CSI_DATA_H_IDX,
86
87 /* keep last */
88 NUM_MTK_VENDOR_ATTRS_CSI_DATA,
89 MTK_VENDOR_ATTR_CSI_DATA_MAX =
90 NUM_MTK_VENDOR_ATTRS_CSI_DATA - 1
91};
92
developere53f0872021-07-23 11:13:49 +080093enum mtk_vendor_attr_mnt_ctrl {
94 MTK_VENDOR_ATTR_AMNT_CTRL_UNSPEC,
95
96 MTK_VENDOR_ATTR_AMNT_CTRL_SET,
97 MTK_VENDOR_ATTR_AMNT_CTRL_DUMP,
98 /* keep last */
99 NUM_MTK_VENDOR_ATTRS_AMNT_CTRL,
100 MTK_VENDOR_ATTR_AMNT_CTRL_MAX =
101 NUM_MTK_VENDOR_ATTRS_AMNT_CTRL - 1
102};
103
104enum mtk_vendor_attr_mnt_set {
105 MTK_VENDOR_ATTR_AMNT_SET_UNSPEC,
106
107 MTK_VENDOR_ATTR_AMNT_SET_INDEX,
108 MTK_VENDOR_ATTR_AMNT_SET_MACADDR,
109
110 /* keep last */
111 NUM_MTK_VENDOR_ATTRS_AMNT_SET,
112 MTK_VENDOR_ATTR_AMNT_SET_MAX =
113 NUM_MTK_VENDOR_ATTRS_AMNT_SET - 1
114};
115
116enum mtk_vendor_attr_mnt_dump {
117 MTK_VENDOR_ATTR_AMNT_DUMP_UNSPEC,
118
119 MTK_VENDOR_ATTR_AMNT_DUMP_INDEX,
120 MTK_VENDOR_ATTR_AMNT_DUMP_LEN,
121 MTK_VENDOR_ATTR_AMNT_DUMP_RESULT,
122
123 /* keep last */
124 NUM_MTK_VENDOR_ATTRS_AMNT_DUMP,
125 MTK_VENDOR_ATTR_AMNT_DUMP_MAX =
126 NUM_MTK_VENDOR_ATTRS_AMNT_DUMP - 1
127};
128
developer5f18e6c2021-07-28 11:55:08 +0800129enum mtk_vendor_attr_wireless_ctrl {
130 MTK_VENDOR_ATTR_WIRELESS_CTRL_UNSPEC,
131
132 MTK_VENDOR_ATTR_WIRELESS_CTRL_FIXED_MCS,
developer507ff0c2021-07-30 14:51:55 +0800133 MTK_VENDOR_ATTR_WIRELESS_CTRL_FIXED_OFDMA,
developer5f18e6c2021-07-28 11:55:08 +0800134
135 /* keep last */
136 NUM_MTK_VENDOR_ATTRS_WIRELESS_CTRL,
137 MTK_VENDOR_ATTR_WIRELESS_CTRL_MAX =
138 NUM_MTK_VENDOR_ATTRS_WIRELESS_CTRL - 1
139};
140
141enum mtk_vendor_attr_rfeature_ctrl {
142 MTK_VENDOR_ATTR_RFEATURE_CTRL_UNSPEC,
143
144 MTK_VENDOR_ATTR_RFEATURE_CTRL_HE_GI,
145 MTK_VENDOR_ATTR_RFEATURE_CTRL_HE_LTF,
developer31b1a282021-08-04 14:13:00 +0800146 MTK_VENDOR_ATTR_RFEATURE_CTRL_TRIG_TYPE,
147 MTK_VENDOR_ATTR_RFEATURE_CTRL_ACK_PLCY,
developer5f18e6c2021-07-28 11:55:08 +0800148
149 /* keep last */
150 NUM_MTK_VENDOR_ATTRS_RFEATURE_CTRL,
151 MTK_VENDOR_ATTR_RFEATURE_CTRL_MAX =
152 NUM_MTK_VENDOR_ATTRS_RFEATURE_CTRL - 1
153};
154
developerfd40db22021-04-29 10:08:25 +0800155#define CSI_MAX_COUNT 256
156#define ETH_ALEN 6
157
158struct csi_data {
159 s16 data_i[CSI_MAX_COUNT];
160 s16 data_q[CSI_MAX_COUNT];
161 s8 rssi;
162 u8 snr;
developera1e20de2021-06-17 10:33:53 +0800163 u32 ts;
developerfd40db22021-04-29 10:08:25 +0800164 u8 data_bw;
165 u8 pri_ch_idx;
166 u8 ta[ETH_ALEN];
167 u32 info;
168 u8 rx_mode;
169 u32 h_idx;
170 u16 tx_idx;
171 u16 rx_idx;
172};
173
developere53f0872021-07-23 11:13:49 +0800174struct amnt_data {
175 u8 idx;
176 u8 addr[ETH_ALEN];
177 s8 rssi[4];
178 u32 last_seen;
179};
180
developerfd40db22021-04-29 10:08:25 +0800181extern struct unl unl;
developerfd40db22021-04-29 10:08:25 +0800182
developer175704f2021-06-22 17:33:53 +0800183int mt76_csi_set(int idx, int argc, char **argv);
184int mt76_csi_dump(int idx, int argc, char **argv);
developerfd40db22021-04-29 10:08:25 +0800185
developere53f0872021-07-23 11:13:49 +0800186int mt76_amnt_set(int idx, int argc, char **argv);
187int mt76_amnt_dump(int idx, int argc, char **argv);
188
developer5f18e6c2021-07-28 11:55:08 +0800189int mt76_ap_rfeatures_set(int idx, int argc, char **argv);
190int mt76_ap_wireless_set(int idx, int argc, char **argv);
developerfd40db22021-04-29 10:08:25 +0800191#endif