xref: /netbsd-src/external/bsd/wpa/dist/src/utils/radiotap.h (revision 45d3cc13f775755ee348416d64536fb30df46e06)
18dbcf02cSchristos /*
2*45d3cc13Schristos  * Copyright (c) 2017		Intel Deutschland GmbH
38dbcf02cSchristos  *
4*45d3cc13Schristos  * Permission to use, copy, modify, and/or distribute this software for any
5*45d3cc13Schristos  * purpose with or without fee is hereby granted, provided that the above
6*45d3cc13Schristos  * copyright notice and this permission notice appear in all copies.
78dbcf02cSchristos  *
8*45d3cc13Schristos  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
9*45d3cc13Schristos  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
10*45d3cc13Schristos  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
11*45d3cc13Schristos  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
12*45d3cc13Schristos  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
13*45d3cc13Schristos  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
14*45d3cc13Schristos  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
158dbcf02cSchristos  */
16*45d3cc13Schristos #ifndef __RADIOTAP_H
17*45d3cc13Schristos #define __RADIOTAP_H
188dbcf02cSchristos 
19*45d3cc13Schristos /**
20*45d3cc13Schristos  * struct ieee82011_radiotap_header - base radiotap header
218dbcf02cSchristos  */
228dbcf02cSchristos struct ieee80211_radiotap_header {
23*45d3cc13Schristos 	/**
24*45d3cc13Schristos 	 * @it_version: radiotap version, always 0
25*45d3cc13Schristos 	 */
26*45d3cc13Schristos 	uint8_t it_version;
27*45d3cc13Schristos 
28*45d3cc13Schristos 	/**
29*45d3cc13Schristos 	 * @it_pad: padding (or alignment)
308dbcf02cSchristos 	 */
318dbcf02cSchristos 	uint8_t it_pad;
328dbcf02cSchristos 
33*45d3cc13Schristos 	/**
34*45d3cc13Schristos 	 * @it_len: overall radiotap header length
358dbcf02cSchristos 	 */
36*45d3cc13Schristos 	le16 it_len;
37*45d3cc13Schristos 
38*45d3cc13Schristos 	/**
39*45d3cc13Schristos 	 * @it_present: (first) present word
40*45d3cc13Schristos 	 */
41*45d3cc13Schristos 	le32 it_present;
42*45d3cc13Schristos } STRUCT_PACKED;
43*45d3cc13Schristos 
44*45d3cc13Schristos /* version is always 0 */
45*45d3cc13Schristos #define PKTHDR_RADIOTAP_VERSION	0
46*45d3cc13Schristos 
47*45d3cc13Schristos /* see the radiotap website for the descriptions */
48*45d3cc13Schristos enum ieee80211_radiotap_presence {
498dbcf02cSchristos 	IEEE80211_RADIOTAP_TSFT = 0,
508dbcf02cSchristos 	IEEE80211_RADIOTAP_FLAGS = 1,
518dbcf02cSchristos 	IEEE80211_RADIOTAP_RATE = 2,
528dbcf02cSchristos 	IEEE80211_RADIOTAP_CHANNEL = 3,
538dbcf02cSchristos 	IEEE80211_RADIOTAP_FHSS = 4,
548dbcf02cSchristos 	IEEE80211_RADIOTAP_DBM_ANTSIGNAL = 5,
558dbcf02cSchristos 	IEEE80211_RADIOTAP_DBM_ANTNOISE = 6,
568dbcf02cSchristos 	IEEE80211_RADIOTAP_LOCK_QUALITY = 7,
578dbcf02cSchristos 	IEEE80211_RADIOTAP_TX_ATTENUATION = 8,
588dbcf02cSchristos 	IEEE80211_RADIOTAP_DB_TX_ATTENUATION = 9,
598dbcf02cSchristos 	IEEE80211_RADIOTAP_DBM_TX_POWER = 10,
608dbcf02cSchristos 	IEEE80211_RADIOTAP_ANTENNA = 11,
618dbcf02cSchristos 	IEEE80211_RADIOTAP_DB_ANTSIGNAL = 12,
628dbcf02cSchristos 	IEEE80211_RADIOTAP_DB_ANTNOISE = 13,
638dbcf02cSchristos 	IEEE80211_RADIOTAP_RX_FLAGS = 14,
648dbcf02cSchristos 	IEEE80211_RADIOTAP_TX_FLAGS = 15,
658dbcf02cSchristos 	IEEE80211_RADIOTAP_RTS_RETRIES = 16,
668dbcf02cSchristos 	IEEE80211_RADIOTAP_DATA_RETRIES = 17,
67*45d3cc13Schristos 	/* 18 is XChannel, but it's not defined yet */
683c5783d3Schristos 	IEEE80211_RADIOTAP_MCS = 19,
693c5783d3Schristos 	IEEE80211_RADIOTAP_AMPDU_STATUS = 20,
70*45d3cc13Schristos 	IEEE80211_RADIOTAP_VHT = 21,
71*45d3cc13Schristos 	IEEE80211_RADIOTAP_TIMESTAMP = 22,
723c5783d3Schristos 
733c5783d3Schristos 	/* valid in every it_present bitmap, even vendor namespaces */
743c5783d3Schristos 	IEEE80211_RADIOTAP_RADIOTAP_NAMESPACE = 29,
753c5783d3Schristos 	IEEE80211_RADIOTAP_VENDOR_NAMESPACE = 30,
768dbcf02cSchristos 	IEEE80211_RADIOTAP_EXT = 31
778dbcf02cSchristos };
788dbcf02cSchristos 
79*45d3cc13Schristos /* for IEEE80211_RADIOTAP_FLAGS */
80*45d3cc13Schristos enum ieee80211_radiotap_flags {
81*45d3cc13Schristos 	IEEE80211_RADIOTAP_F_CFP = 0x01,
82*45d3cc13Schristos 	IEEE80211_RADIOTAP_F_SHORTPRE = 0x02,
83*45d3cc13Schristos 	IEEE80211_RADIOTAP_F_WEP = 0x04,
84*45d3cc13Schristos 	IEEE80211_RADIOTAP_F_FRAG = 0x08,
85*45d3cc13Schristos 	IEEE80211_RADIOTAP_F_FCS = 0x10,
86*45d3cc13Schristos 	IEEE80211_RADIOTAP_F_DATAPAD = 0x20,
87*45d3cc13Schristos 	IEEE80211_RADIOTAP_F_BADFCS = 0x40,
88*45d3cc13Schristos };
898dbcf02cSchristos 
90*45d3cc13Schristos /* for IEEE80211_RADIOTAP_CHANNEL */
91*45d3cc13Schristos enum ieee80211_radiotap_channel_flags {
92*45d3cc13Schristos 	IEEE80211_CHAN_CCK = 0x0020,
93*45d3cc13Schristos 	IEEE80211_CHAN_OFDM = 0x0040,
94*45d3cc13Schristos 	IEEE80211_CHAN_2GHZ = 0x0080,
95*45d3cc13Schristos 	IEEE80211_CHAN_5GHZ = 0x0100,
96*45d3cc13Schristos 	IEEE80211_CHAN_DYN = 0x0400,
97*45d3cc13Schristos 	IEEE80211_CHAN_HALF = 0x4000,
98*45d3cc13Schristos 	IEEE80211_CHAN_QUARTER = 0x8000,
99*45d3cc13Schristos };
1003c5783d3Schristos 
101*45d3cc13Schristos /* for IEEE80211_RADIOTAP_RX_FLAGS */
102*45d3cc13Schristos enum ieee80211_radiotap_rx_flags {
103*45d3cc13Schristos 	IEEE80211_RADIOTAP_F_RX_BADPLCP = 0x0002,
104*45d3cc13Schristos };
1058dbcf02cSchristos 
106*45d3cc13Schristos /* for IEEE80211_RADIOTAP_TX_FLAGS */
107*45d3cc13Schristos enum ieee80211_radiotap_tx_flags {
108*45d3cc13Schristos 	IEEE80211_RADIOTAP_F_TX_FAIL = 0x0001,
109*45d3cc13Schristos 	IEEE80211_RADIOTAP_F_TX_CTS = 0x0002,
110*45d3cc13Schristos 	IEEE80211_RADIOTAP_F_TX_RTS = 0x0004,
111*45d3cc13Schristos 	IEEE80211_RADIOTAP_F_TX_NOACK = 0x0008,
112*45d3cc13Schristos };
1138dbcf02cSchristos 
114*45d3cc13Schristos /* for IEEE80211_RADIOTAP_MCS "have" flags */
115*45d3cc13Schristos enum ieee80211_radiotap_mcs_have {
116*45d3cc13Schristos 	IEEE80211_RADIOTAP_MCS_HAVE_BW = 0x01,
117*45d3cc13Schristos 	IEEE80211_RADIOTAP_MCS_HAVE_MCS = 0x02,
118*45d3cc13Schristos 	IEEE80211_RADIOTAP_MCS_HAVE_GI = 0x04,
119*45d3cc13Schristos 	IEEE80211_RADIOTAP_MCS_HAVE_FMT = 0x08,
120*45d3cc13Schristos 	IEEE80211_RADIOTAP_MCS_HAVE_FEC = 0x10,
121*45d3cc13Schristos 	IEEE80211_RADIOTAP_MCS_HAVE_STBC = 0x20,
122*45d3cc13Schristos };
1233c5783d3Schristos 
124*45d3cc13Schristos enum ieee80211_radiotap_mcs_flags {
125*45d3cc13Schristos 	IEEE80211_RADIOTAP_MCS_BW_MASK = 0x03,
126*45d3cc13Schristos 	IEEE80211_RADIOTAP_MCS_BW_20 = 0,
127*45d3cc13Schristos 	IEEE80211_RADIOTAP_MCS_BW_40 = 1,
128*45d3cc13Schristos 	IEEE80211_RADIOTAP_MCS_BW_20L = 2,
129*45d3cc13Schristos 	IEEE80211_RADIOTAP_MCS_BW_20U = 3,
1303c5783d3Schristos 
131*45d3cc13Schristos 	IEEE80211_RADIOTAP_MCS_SGI = 0x04,
132*45d3cc13Schristos 	IEEE80211_RADIOTAP_MCS_FMT_GF = 0x08,
133*45d3cc13Schristos 	IEEE80211_RADIOTAP_MCS_FEC_LDPC = 0x10,
134*45d3cc13Schristos 	IEEE80211_RADIOTAP_MCS_STBC_MASK = 0x60,
135*45d3cc13Schristos 	IEEE80211_RADIOTAP_MCS_STBC_1 = 1,
136*45d3cc13Schristos 	IEEE80211_RADIOTAP_MCS_STBC_2 = 2,
137*45d3cc13Schristos 	IEEE80211_RADIOTAP_MCS_STBC_3 = 3,
138*45d3cc13Schristos 	IEEE80211_RADIOTAP_MCS_STBC_SHIFT = 5,
139*45d3cc13Schristos };
1403c5783d3Schristos 
141*45d3cc13Schristos /* for IEEE80211_RADIOTAP_AMPDU_STATUS */
142*45d3cc13Schristos enum ieee80211_radiotap_ampdu_flags {
143*45d3cc13Schristos 	IEEE80211_RADIOTAP_AMPDU_REPORT_ZEROLEN = 0x0001,
144*45d3cc13Schristos 	IEEE80211_RADIOTAP_AMPDU_IS_ZEROLEN = 0x0002,
145*45d3cc13Schristos 	IEEE80211_RADIOTAP_AMPDU_LAST_KNOWN = 0x0004,
146*45d3cc13Schristos 	IEEE80211_RADIOTAP_AMPDU_IS_LAST = 0x0008,
147*45d3cc13Schristos 	IEEE80211_RADIOTAP_AMPDU_DELIM_CRC_ERR = 0x0010,
148*45d3cc13Schristos 	IEEE80211_RADIOTAP_AMPDU_DELIM_CRC_KNOWN = 0x0020,
149*45d3cc13Schristos };
1503c5783d3Schristos 
151*45d3cc13Schristos /* for IEEE80211_RADIOTAP_VHT */
152*45d3cc13Schristos enum ieee80211_radiotap_vht_known {
153*45d3cc13Schristos 	IEEE80211_RADIOTAP_VHT_KNOWN_STBC = 0x0001,
154*45d3cc13Schristos 	IEEE80211_RADIOTAP_VHT_KNOWN_TXOP_PS_NA = 0x0002,
155*45d3cc13Schristos 	IEEE80211_RADIOTAP_VHT_KNOWN_GI = 0x0004,
156*45d3cc13Schristos 	IEEE80211_RADIOTAP_VHT_KNOWN_SGI_NSYM_DIS = 0x0008,
157*45d3cc13Schristos 	IEEE80211_RADIOTAP_VHT_KNOWN_LDPC_EXTRA_OFDM_SYM = 0x0010,
158*45d3cc13Schristos 	IEEE80211_RADIOTAP_VHT_KNOWN_BEAMFORMED = 0x0020,
159*45d3cc13Schristos 	IEEE80211_RADIOTAP_VHT_KNOWN_BANDWIDTH = 0x0040,
160*45d3cc13Schristos 	IEEE80211_RADIOTAP_VHT_KNOWN_GROUP_ID = 0x0080,
161*45d3cc13Schristos 	IEEE80211_RADIOTAP_VHT_KNOWN_PARTIAL_AID = 0x0100,
162*45d3cc13Schristos };
163*45d3cc13Schristos 
164*45d3cc13Schristos enum ieee80211_radiotap_vht_flags {
165*45d3cc13Schristos 	IEEE80211_RADIOTAP_VHT_FLAG_STBC = 0x01,
166*45d3cc13Schristos 	IEEE80211_RADIOTAP_VHT_FLAG_TXOP_PS_NA = 0x02,
167*45d3cc13Schristos 	IEEE80211_RADIOTAP_VHT_FLAG_SGI = 0x04,
168*45d3cc13Schristos 	IEEE80211_RADIOTAP_VHT_FLAG_SGI_NSYM_M10_9 = 0x08,
169*45d3cc13Schristos 	IEEE80211_RADIOTAP_VHT_FLAG_LDPC_EXTRA_OFDM_SYM = 0x10,
170*45d3cc13Schristos 	IEEE80211_RADIOTAP_VHT_FLAG_BEAMFORMED = 0x20,
171*45d3cc13Schristos };
172*45d3cc13Schristos 
173*45d3cc13Schristos enum ieee80211_radiotap_vht_coding {
174*45d3cc13Schristos 	IEEE80211_RADIOTAP_CODING_LDPC_USER0 = 0x01,
175*45d3cc13Schristos 	IEEE80211_RADIOTAP_CODING_LDPC_USER1 = 0x02,
176*45d3cc13Schristos 	IEEE80211_RADIOTAP_CODING_LDPC_USER2 = 0x04,
177*45d3cc13Schristos 	IEEE80211_RADIOTAP_CODING_LDPC_USER3 = 0x08,
178*45d3cc13Schristos };
179*45d3cc13Schristos 
180*45d3cc13Schristos /* for IEEE80211_RADIOTAP_TIMESTAMP */
181*45d3cc13Schristos enum ieee80211_radiotap_timestamp_unit_spos {
182*45d3cc13Schristos 	IEEE80211_RADIOTAP_TIMESTAMP_UNIT_MASK = 0x000F,
183*45d3cc13Schristos 	IEEE80211_RADIOTAP_TIMESTAMP_UNIT_MS = 0x0000,
184*45d3cc13Schristos 	IEEE80211_RADIOTAP_TIMESTAMP_UNIT_US = 0x0001,
185*45d3cc13Schristos 	IEEE80211_RADIOTAP_TIMESTAMP_UNIT_NS = 0x0003,
186*45d3cc13Schristos 	IEEE80211_RADIOTAP_TIMESTAMP_SPOS_MASK = 0x00F0,
187*45d3cc13Schristos 	IEEE80211_RADIOTAP_TIMESTAMP_SPOS_BEGIN_MDPU = 0x0000,
188*45d3cc13Schristos 	IEEE80211_RADIOTAP_TIMESTAMP_SPOS_PLCP_SIG_ACQ = 0x0010,
189*45d3cc13Schristos 	IEEE80211_RADIOTAP_TIMESTAMP_SPOS_EO_PPDU = 0x0020,
190*45d3cc13Schristos 	IEEE80211_RADIOTAP_TIMESTAMP_SPOS_EO_MPDU = 0x0030,
191*45d3cc13Schristos 	IEEE80211_RADIOTAP_TIMESTAMP_SPOS_UNKNOWN = 0x00F0,
192*45d3cc13Schristos };
193*45d3cc13Schristos 
194*45d3cc13Schristos enum ieee80211_radiotap_timestamp_flags {
195*45d3cc13Schristos 	IEEE80211_RADIOTAP_TIMESTAMP_FLAG_64BIT = 0x00,
196*45d3cc13Schristos 	IEEE80211_RADIOTAP_TIMESTAMP_FLAG_32BIT = 0x01,
197*45d3cc13Schristos 	IEEE80211_RADIOTAP_TIMESTAMP_FLAG_ACCURACY = 0x02,
198*45d3cc13Schristos };
199*45d3cc13Schristos 
200*45d3cc13Schristos #endif /* __RADIOTAP_H */
201