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