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