xref: /freebsd/sys/contrib/dev/mediatek/mt76/testmode.h (revision 6c92544d7c9722a3fe6263134938d1f864c158c5)
1*6c92544dSBjoern A. Zeeb /* SPDX-License-Identifier: ISC */
2*6c92544dSBjoern A. Zeeb /*
3*6c92544dSBjoern A. Zeeb  * Copyright (C) 2020 Felix Fietkau <nbd@nbd.name>
4*6c92544dSBjoern A. Zeeb  */
5*6c92544dSBjoern A. Zeeb #ifndef __MT76_TESTMODE_H
6*6c92544dSBjoern A. Zeeb #define __MT76_TESTMODE_H
7*6c92544dSBjoern A. Zeeb 
8*6c92544dSBjoern A. Zeeb #define MT76_TM_TIMEOUT	10
9*6c92544dSBjoern A. Zeeb 
10*6c92544dSBjoern A. Zeeb #include <net/netlink.h>
11*6c92544dSBjoern A. Zeeb 
12*6c92544dSBjoern A. Zeeb /**
13*6c92544dSBjoern A. Zeeb  * enum mt76_testmode_attr - testmode attributes inside NL80211_ATTR_TESTDATA
14*6c92544dSBjoern A. Zeeb  *
15*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_UNSPEC: (invalid attribute)
16*6c92544dSBjoern A. Zeeb  *
17*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_RESET: reset parameters to default (flag)
18*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_STATE: test state (u32), see &enum mt76_testmode_state
19*6c92544dSBjoern A. Zeeb  *
20*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_MTD_PART: mtd partition used for eeprom data (string)
21*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_MTD_OFFSET: offset of eeprom data within the partition (u32)
22*6c92544dSBjoern A. Zeeb  *
23*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_TX_COUNT: configured number of frames to send when setting
24*6c92544dSBjoern A. Zeeb  *	state to MT76_TM_STATE_TX_FRAMES (u32)
25*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_TX_PENDING: pending frames during MT76_TM_STATE_TX_FRAMES (u32)
26*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_TX_LENGTH: packet tx mpdu length (u32)
27*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_TX_RATE_MODE: packet tx mode (u8, see &enum mt76_testmode_tx_mode)
28*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_TX_RATE_NSS: packet tx number of spatial streams (u8)
29*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_TX_RATE_IDX: packet tx rate/MCS index (u8)
30*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_TX_RATE_SGI: packet tx use short guard interval (u8)
31*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_TX_RATE_LDPC: packet tx enable LDPC (u8)
32*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_TX_RATE_STBC: packet tx enable STBC (u8)
33*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_TX_LTF: packet tx LTF, set 0 to 2 for 1x, 2x, and 4x LTF (u8)
34*6c92544dSBjoern A. Zeeb  *
35*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_TX_ANTENNA: tx antenna mask (u8)
36*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_TX_POWER_CONTROL: enable tx power control (u8)
37*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_TX_POWER: per-antenna tx power array (nested, u8 attrs)
38*6c92544dSBjoern A. Zeeb  *
39*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_FREQ_OFFSET: RF frequency offset (u32)
40*6c92544dSBjoern A. Zeeb  *
41*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_STATS: statistics (nested, see &enum mt76_testmode_stats_attr)
42*6c92544dSBjoern A. Zeeb  *
43*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_TX_SPE_IDX: tx spatial extension index (u8)
44*6c92544dSBjoern A. Zeeb  *
45*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_TX_DUTY_CYCLE: packet tx duty cycle (u8)
46*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_TX_IPG: tx inter-packet gap, in unit of us (u32)
47*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_TX_TIME: packet transmission time, in unit of us (u32)
48*6c92544dSBjoern A. Zeeb  *
49*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_DRV_DATA: driver specific netlink attrs (nested)
50*6c92544dSBjoern A. Zeeb  *
51*6c92544dSBjoern A. Zeeb  * @MT76_TM_ATTR_MAC_ADDRS: array of nested MAC addresses (nested)
52*6c92544dSBjoern A. Zeeb  */
53*6c92544dSBjoern A. Zeeb enum mt76_testmode_attr {
54*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_UNSPEC,
55*6c92544dSBjoern A. Zeeb 
56*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_RESET,
57*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_STATE,
58*6c92544dSBjoern A. Zeeb 
59*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_MTD_PART,
60*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_MTD_OFFSET,
61*6c92544dSBjoern A. Zeeb 
62*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_TX_COUNT,
63*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_TX_LENGTH,
64*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_TX_RATE_MODE,
65*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_TX_RATE_NSS,
66*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_TX_RATE_IDX,
67*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_TX_RATE_SGI,
68*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_TX_RATE_LDPC,
69*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_TX_RATE_STBC,
70*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_TX_LTF,
71*6c92544dSBjoern A. Zeeb 
72*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_TX_ANTENNA,
73*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_TX_POWER_CONTROL,
74*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_TX_POWER,
75*6c92544dSBjoern A. Zeeb 
76*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_FREQ_OFFSET,
77*6c92544dSBjoern A. Zeeb 
78*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_STATS,
79*6c92544dSBjoern A. Zeeb 
80*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_TX_SPE_IDX,
81*6c92544dSBjoern A. Zeeb 
82*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_TX_DUTY_CYCLE,
83*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_TX_IPG,
84*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_TX_TIME,
85*6c92544dSBjoern A. Zeeb 
86*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_DRV_DATA,
87*6c92544dSBjoern A. Zeeb 
88*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_MAC_ADDRS,
89*6c92544dSBjoern A. Zeeb 
90*6c92544dSBjoern A. Zeeb 	/* keep last */
91*6c92544dSBjoern A. Zeeb 	NUM_MT76_TM_ATTRS,
92*6c92544dSBjoern A. Zeeb 	MT76_TM_ATTR_MAX = NUM_MT76_TM_ATTRS - 1,
93*6c92544dSBjoern A. Zeeb };
94*6c92544dSBjoern A. Zeeb 
95*6c92544dSBjoern A. Zeeb /**
96*6c92544dSBjoern A. Zeeb  * enum mt76_testmode_state - statistics attributes
97*6c92544dSBjoern A. Zeeb  *
98*6c92544dSBjoern A. Zeeb  * @MT76_TM_STATS_ATTR_TX_PENDING: pending tx frames (u32)
99*6c92544dSBjoern A. Zeeb  * @MT76_TM_STATS_ATTR_TX_QUEUED: queued tx frames (u32)
100*6c92544dSBjoern A. Zeeb  * @MT76_TM_STATS_ATTR_TX_QUEUED: completed tx frames (u32)
101*6c92544dSBjoern A. Zeeb  *
102*6c92544dSBjoern A. Zeeb  * @MT76_TM_STATS_ATTR_RX_PACKETS: number of rx packets (u64)
103*6c92544dSBjoern A. Zeeb  * @MT76_TM_STATS_ATTR_RX_FCS_ERROR: number of rx packets with FCS error (u64)
104*6c92544dSBjoern A. Zeeb  * @MT76_TM_STATS_ATTR_LAST_RX: information about the last received packet
105*6c92544dSBjoern A. Zeeb  *	see &enum mt76_testmode_rx_attr
106*6c92544dSBjoern A. Zeeb  */
107*6c92544dSBjoern A. Zeeb enum mt76_testmode_stats_attr {
108*6c92544dSBjoern A. Zeeb 	MT76_TM_STATS_ATTR_UNSPEC,
109*6c92544dSBjoern A. Zeeb 	MT76_TM_STATS_ATTR_PAD,
110*6c92544dSBjoern A. Zeeb 
111*6c92544dSBjoern A. Zeeb 	MT76_TM_STATS_ATTR_TX_PENDING,
112*6c92544dSBjoern A. Zeeb 	MT76_TM_STATS_ATTR_TX_QUEUED,
113*6c92544dSBjoern A. Zeeb 	MT76_TM_STATS_ATTR_TX_DONE,
114*6c92544dSBjoern A. Zeeb 
115*6c92544dSBjoern A. Zeeb 	MT76_TM_STATS_ATTR_RX_PACKETS,
116*6c92544dSBjoern A. Zeeb 	MT76_TM_STATS_ATTR_RX_FCS_ERROR,
117*6c92544dSBjoern A. Zeeb 	MT76_TM_STATS_ATTR_LAST_RX,
118*6c92544dSBjoern A. Zeeb 
119*6c92544dSBjoern A. Zeeb 	/* keep last */
120*6c92544dSBjoern A. Zeeb 	NUM_MT76_TM_STATS_ATTRS,
121*6c92544dSBjoern A. Zeeb 	MT76_TM_STATS_ATTR_MAX = NUM_MT76_TM_STATS_ATTRS - 1,
122*6c92544dSBjoern A. Zeeb };
123*6c92544dSBjoern A. Zeeb 
124*6c92544dSBjoern A. Zeeb 
125*6c92544dSBjoern A. Zeeb /**
126*6c92544dSBjoern A. Zeeb  * enum mt76_testmode_rx_attr - packet rx information
127*6c92544dSBjoern A. Zeeb  *
128*6c92544dSBjoern A. Zeeb  * @MT76_TM_RX_ATTR_FREQ_OFFSET: frequency offset (s32)
129*6c92544dSBjoern A. Zeeb  * @MT76_TM_RX_ATTR_RCPI: received channel power indicator (array, u8)
130*6c92544dSBjoern A. Zeeb  * @MT76_TM_RX_ATTR_IB_RSSI: internal inband RSSI (array, s8)
131*6c92544dSBjoern A. Zeeb  * @MT76_TM_RX_ATTR_WB_RSSI: internal wideband RSSI (array, s8)
132*6c92544dSBjoern A. Zeeb  * @MT76_TM_RX_ATTR_SNR: signal-to-noise ratio (u8)
133*6c92544dSBjoern A. Zeeb  */
134*6c92544dSBjoern A. Zeeb enum mt76_testmode_rx_attr {
135*6c92544dSBjoern A. Zeeb 	MT76_TM_RX_ATTR_UNSPEC,
136*6c92544dSBjoern A. Zeeb 
137*6c92544dSBjoern A. Zeeb 	MT76_TM_RX_ATTR_FREQ_OFFSET,
138*6c92544dSBjoern A. Zeeb 	MT76_TM_RX_ATTR_RCPI,
139*6c92544dSBjoern A. Zeeb 	MT76_TM_RX_ATTR_IB_RSSI,
140*6c92544dSBjoern A. Zeeb 	MT76_TM_RX_ATTR_WB_RSSI,
141*6c92544dSBjoern A. Zeeb 	MT76_TM_RX_ATTR_SNR,
142*6c92544dSBjoern A. Zeeb 
143*6c92544dSBjoern A. Zeeb 	/* keep last */
144*6c92544dSBjoern A. Zeeb 	NUM_MT76_TM_RX_ATTRS,
145*6c92544dSBjoern A. Zeeb 	MT76_TM_RX_ATTR_MAX = NUM_MT76_TM_RX_ATTRS - 1,
146*6c92544dSBjoern A. Zeeb };
147*6c92544dSBjoern A. Zeeb 
148*6c92544dSBjoern A. Zeeb /**
149*6c92544dSBjoern A. Zeeb  * enum mt76_testmode_state - phy test state
150*6c92544dSBjoern A. Zeeb  *
151*6c92544dSBjoern A. Zeeb  * @MT76_TM_STATE_OFF: test mode disabled (normal operation)
152*6c92544dSBjoern A. Zeeb  * @MT76_TM_STATE_IDLE: test mode enabled, but idle
153*6c92544dSBjoern A. Zeeb  * @MT76_TM_STATE_TX_FRAMES: send a fixed number of test frames
154*6c92544dSBjoern A. Zeeb  * @MT76_TM_STATE_RX_FRAMES: receive packets and keep statistics
155*6c92544dSBjoern A. Zeeb  * @MT76_TM_STATE_TX_CONT: waveform tx without time gap
156*6c92544dSBjoern A. Zeeb  * @MT76_TM_STATE_ON: test mode enabled used in offload firmware
157*6c92544dSBjoern A. Zeeb  */
158*6c92544dSBjoern A. Zeeb enum mt76_testmode_state {
159*6c92544dSBjoern A. Zeeb 	MT76_TM_STATE_OFF,
160*6c92544dSBjoern A. Zeeb 	MT76_TM_STATE_IDLE,
161*6c92544dSBjoern A. Zeeb 	MT76_TM_STATE_TX_FRAMES,
162*6c92544dSBjoern A. Zeeb 	MT76_TM_STATE_RX_FRAMES,
163*6c92544dSBjoern A. Zeeb 	MT76_TM_STATE_TX_CONT,
164*6c92544dSBjoern A. Zeeb 	MT76_TM_STATE_ON,
165*6c92544dSBjoern A. Zeeb 
166*6c92544dSBjoern A. Zeeb 	/* keep last */
167*6c92544dSBjoern A. Zeeb 	NUM_MT76_TM_STATES,
168*6c92544dSBjoern A. Zeeb 	MT76_TM_STATE_MAX = NUM_MT76_TM_STATES - 1,
169*6c92544dSBjoern A. Zeeb };
170*6c92544dSBjoern A. Zeeb 
171*6c92544dSBjoern A. Zeeb /**
172*6c92544dSBjoern A. Zeeb  * enum mt76_testmode_tx_mode - packet tx phy mode
173*6c92544dSBjoern A. Zeeb  *
174*6c92544dSBjoern A. Zeeb  * @MT76_TM_TX_MODE_CCK: legacy CCK mode
175*6c92544dSBjoern A. Zeeb  * @MT76_TM_TX_MODE_OFDM: legacy OFDM mode
176*6c92544dSBjoern A. Zeeb  * @MT76_TM_TX_MODE_HT: 802.11n MCS
177*6c92544dSBjoern A. Zeeb  * @MT76_TM_TX_MODE_VHT: 802.11ac MCS
178*6c92544dSBjoern A. Zeeb  * @MT76_TM_TX_MODE_HE_SU: 802.11ax single-user MIMO
179*6c92544dSBjoern A. Zeeb  * @MT76_TM_TX_MODE_HE_EXT_SU: 802.11ax extended-range SU
180*6c92544dSBjoern A. Zeeb  * @MT76_TM_TX_MODE_HE_TB: 802.11ax trigger-based
181*6c92544dSBjoern A. Zeeb  * @MT76_TM_TX_MODE_HE_MU: 802.11ax multi-user MIMO
182*6c92544dSBjoern A. Zeeb  */
183*6c92544dSBjoern A. Zeeb enum mt76_testmode_tx_mode {
184*6c92544dSBjoern A. Zeeb 	MT76_TM_TX_MODE_CCK,
185*6c92544dSBjoern A. Zeeb 	MT76_TM_TX_MODE_OFDM,
186*6c92544dSBjoern A. Zeeb 	MT76_TM_TX_MODE_HT,
187*6c92544dSBjoern A. Zeeb 	MT76_TM_TX_MODE_VHT,
188*6c92544dSBjoern A. Zeeb 	MT76_TM_TX_MODE_HE_SU,
189*6c92544dSBjoern A. Zeeb 	MT76_TM_TX_MODE_HE_EXT_SU,
190*6c92544dSBjoern A. Zeeb 	MT76_TM_TX_MODE_HE_TB,
191*6c92544dSBjoern A. Zeeb 	MT76_TM_TX_MODE_HE_MU,
192*6c92544dSBjoern A. Zeeb 
193*6c92544dSBjoern A. Zeeb 	/* keep last */
194*6c92544dSBjoern A. Zeeb 	NUM_MT76_TM_TX_MODES,
195*6c92544dSBjoern A. Zeeb 	MT76_TM_TX_MODE_MAX = NUM_MT76_TM_TX_MODES - 1,
196*6c92544dSBjoern A. Zeeb };
197*6c92544dSBjoern A. Zeeb 
198*6c92544dSBjoern A. Zeeb extern const struct nla_policy mt76_tm_policy[NUM_MT76_TM_ATTRS];
199*6c92544dSBjoern A. Zeeb 
200*6c92544dSBjoern A. Zeeb #endif
201