ieee80211.h revision 1.18.4.1 1 1.18 degroote /* $NetBSD: ieee80211.h,v 1.18.4.1 2008/02/22 16:50:25 skrll Exp $ */
2 1.1 dyoung /*-
3 1.1 dyoung * Copyright (c) 2001 Atsushi Onoe
4 1.18.4.1 skrll * Copyright (c) 2002-2007 Sam Leffler, Errno Consulting
5 1.1 dyoung * All rights reserved.
6 1.1 dyoung *
7 1.1 dyoung * Redistribution and use in source and binary forms, with or without
8 1.1 dyoung * modification, are permitted provided that the following conditions
9 1.1 dyoung * are met:
10 1.1 dyoung * 1. Redistributions of source code must retain the above copyright
11 1.1 dyoung * notice, this list of conditions and the following disclaimer.
12 1.1 dyoung * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 dyoung * notice, this list of conditions and the following disclaimer in the
14 1.1 dyoung * documentation and/or other materials provided with the distribution.
15 1.1 dyoung *
16 1.1 dyoung * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
17 1.1 dyoung * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
18 1.1 dyoung * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
19 1.1 dyoung * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
20 1.1 dyoung * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
21 1.1 dyoung * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22 1.1 dyoung * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23 1.1 dyoung * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24 1.1 dyoung * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
25 1.1 dyoung * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 1.1 dyoung *
27 1.18.4.1 skrll * $FreeBSD: src/sys/net80211/ieee80211.h,v 1.18 2007/11/23 06:12:46 sam Exp $
28 1.1 dyoung */
29 1.1 dyoung #ifndef _NET80211_IEEE80211_H_
30 1.1 dyoung #define _NET80211_IEEE80211_H_
31 1.1 dyoung
32 1.1 dyoung /*
33 1.1 dyoung * 802.11 protocol definitions.
34 1.1 dyoung */
35 1.1 dyoung
36 1.1 dyoung #define IEEE80211_ADDR_LEN 6 /* size of 802.11 address */
37 1.1 dyoung /* is 802.11 address multicast/broadcast? */
38 1.1 dyoung #define IEEE80211_IS_MULTICAST(_a) (*(_a) & 0x01)
39 1.1 dyoung
40 1.1 dyoung /* IEEE 802.11 PLCP header */
41 1.1 dyoung struct ieee80211_plcp_hdr {
42 1.18.4.1 skrll uint16_t i_sfd;
43 1.18.4.1 skrll uint8_t i_signal;
44 1.18.4.1 skrll uint8_t i_service;
45 1.18.4.1 skrll uint16_t i_length;
46 1.18.4.1 skrll uint16_t i_crc;
47 1.13 dyoung } __packed;
48 1.1 dyoung
49 1.13 dyoung #define IEEE80211_PLCP_SFD 0xF3A0
50 1.13 dyoung #define IEEE80211_PLCP_SERVICE 0x00
51 1.3 dyoung
52 1.1 dyoung /*
53 1.1 dyoung * generic definitions for IEEE 802.11 frames
54 1.1 dyoung */
55 1.1 dyoung struct ieee80211_frame {
56 1.18.4.1 skrll uint8_t i_fc[2];
57 1.18.4.1 skrll uint8_t i_dur[2];
58 1.18.4.1 skrll uint8_t i_addr1[IEEE80211_ADDR_LEN];
59 1.18.4.1 skrll uint8_t i_addr2[IEEE80211_ADDR_LEN];
60 1.18.4.1 skrll uint8_t i_addr3[IEEE80211_ADDR_LEN];
61 1.18.4.1 skrll uint8_t i_seq[2];
62 1.1 dyoung /* possibly followed by addr4[IEEE80211_ADDR_LEN]; */
63 1.1 dyoung /* see below */
64 1.13 dyoung } __packed;
65 1.1 dyoung
66 1.6 dyoung struct ieee80211_qosframe {
67 1.18.4.1 skrll uint8_t i_fc[2];
68 1.18.4.1 skrll uint8_t i_dur[2];
69 1.18.4.1 skrll uint8_t i_addr1[IEEE80211_ADDR_LEN];
70 1.18.4.1 skrll uint8_t i_addr2[IEEE80211_ADDR_LEN];
71 1.18.4.1 skrll uint8_t i_addr3[IEEE80211_ADDR_LEN];
72 1.18.4.1 skrll uint8_t i_seq[2];
73 1.18.4.1 skrll uint8_t i_qos[2];
74 1.6 dyoung /* possibly followed by addr4[IEEE80211_ADDR_LEN]; */
75 1.6 dyoung /* see below */
76 1.13 dyoung } __packed;
77 1.6 dyoung
78 1.6 dyoung struct ieee80211_qoscntl {
79 1.18.4.1 skrll uint8_t i_qos[2];
80 1.6 dyoung };
81 1.6 dyoung
82 1.1 dyoung struct ieee80211_frame_addr4 {
83 1.18.4.1 skrll uint8_t i_fc[2];
84 1.18.4.1 skrll uint8_t i_dur[2];
85 1.18.4.1 skrll uint8_t i_addr1[IEEE80211_ADDR_LEN];
86 1.18.4.1 skrll uint8_t i_addr2[IEEE80211_ADDR_LEN];
87 1.18.4.1 skrll uint8_t i_addr3[IEEE80211_ADDR_LEN];
88 1.18.4.1 skrll uint8_t i_seq[2];
89 1.18.4.1 skrll uint8_t i_addr4[IEEE80211_ADDR_LEN];
90 1.13 dyoung } __packed;
91 1.1 dyoung
92 1.6 dyoung
93 1.6 dyoung struct ieee80211_qosframe_addr4 {
94 1.18.4.1 skrll uint8_t i_fc[2];
95 1.18.4.1 skrll uint8_t i_dur[2];
96 1.18.4.1 skrll uint8_t i_addr1[IEEE80211_ADDR_LEN];
97 1.18.4.1 skrll uint8_t i_addr2[IEEE80211_ADDR_LEN];
98 1.18.4.1 skrll uint8_t i_addr3[IEEE80211_ADDR_LEN];
99 1.18.4.1 skrll uint8_t i_seq[2];
100 1.18.4.1 skrll uint8_t i_addr4[IEEE80211_ADDR_LEN];
101 1.18.4.1 skrll uint8_t i_qos[2];
102 1.13 dyoung } __packed;
103 1.6 dyoung
104 1.1 dyoung #define IEEE80211_FC0_VERSION_MASK 0x03
105 1.1 dyoung #define IEEE80211_FC0_VERSION_SHIFT 0
106 1.1 dyoung #define IEEE80211_FC0_VERSION_0 0x00
107 1.1 dyoung #define IEEE80211_FC0_TYPE_MASK 0x0c
108 1.1 dyoung #define IEEE80211_FC0_TYPE_SHIFT 2
109 1.1 dyoung #define IEEE80211_FC0_TYPE_MGT 0x00
110 1.1 dyoung #define IEEE80211_FC0_TYPE_CTL 0x04
111 1.1 dyoung #define IEEE80211_FC0_TYPE_DATA 0x08
112 1.1 dyoung
113 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_MASK 0xf0
114 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_SHIFT 4
115 1.1 dyoung /* for TYPE_MGT */
116 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_ASSOC_REQ 0x00
117 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_ASSOC_RESP 0x10
118 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_REASSOC_REQ 0x20
119 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_REASSOC_RESP 0x30
120 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_PROBE_REQ 0x40
121 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_PROBE_RESP 0x50
122 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_BEACON 0x80
123 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_ATIM 0x90
124 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_DISASSOC 0xa0
125 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_AUTH 0xb0
126 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_DEAUTH 0xc0
127 1.18.4.1 skrll #define IEEE80211_FC0_SUBTYPE_ACTION 0xd0
128 1.1 dyoung /* for TYPE_CTL */
129 1.18.4.1 skrll #define IEEE80211_FC0_SUBTYPE_BAR 0x80
130 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_PS_POLL 0xa0
131 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_RTS 0xb0
132 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_CTS 0xc0
133 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_ACK 0xd0
134 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_CF_END 0xe0
135 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_CF_END_ACK 0xf0
136 1.1 dyoung /* for TYPE_DATA (bit combination) */
137 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_DATA 0x00
138 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_CF_ACK 0x10
139 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_CF_POLL 0x20
140 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_CF_ACPL 0x30
141 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_NODATA 0x40
142 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_CFACK 0x50
143 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_CFPOLL 0x60
144 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_CF_ACK_CF_ACK 0x70
145 1.6 dyoung #define IEEE80211_FC0_SUBTYPE_QOS 0x80
146 1.13 dyoung #define IEEE80211_FC0_SUBTYPE_QOS_NULL 0xc0
147 1.1 dyoung
148 1.1 dyoung #define IEEE80211_FC1_DIR_MASK 0x03
149 1.1 dyoung #define IEEE80211_FC1_DIR_NODS 0x00 /* STA->STA */
150 1.1 dyoung #define IEEE80211_FC1_DIR_TODS 0x01 /* STA->AP */
151 1.1 dyoung #define IEEE80211_FC1_DIR_FROMDS 0x02 /* AP ->STA */
152 1.1 dyoung #define IEEE80211_FC1_DIR_DSTODS 0x03 /* AP ->AP */
153 1.1 dyoung
154 1.1 dyoung #define IEEE80211_FC1_MORE_FRAG 0x04
155 1.1 dyoung #define IEEE80211_FC1_RETRY 0x08
156 1.1 dyoung #define IEEE80211_FC1_PWR_MGT 0x10
157 1.1 dyoung #define IEEE80211_FC1_MORE_DATA 0x20
158 1.1 dyoung #define IEEE80211_FC1_WEP 0x40
159 1.1 dyoung #define IEEE80211_FC1_ORDER 0x80
160 1.1 dyoung
161 1.1 dyoung #define IEEE80211_SEQ_FRAG_MASK 0x000f
162 1.1 dyoung #define IEEE80211_SEQ_FRAG_SHIFT 0
163 1.1 dyoung #define IEEE80211_SEQ_SEQ_MASK 0xfff0
164 1.1 dyoung #define IEEE80211_SEQ_SEQ_SHIFT 4
165 1.18.4.1 skrll #define IEEE80211_SEQ_RANGE 4096
166 1.18.4.1 skrll
167 1.18.4.1 skrll #define IEEE80211_SEQ_ADD(seq, incr) \
168 1.18.4.1 skrll (((seq) + (incr)) & (IEEE80211_SEQ_RANGE-1))
169 1.18.4.1 skrll #define IEEE80211_SEQ_INC(seq) IEEE80211_SEQ_ADD(seq,1)
170 1.18.4.1 skrll #define IEEE80211_SEQ_SUB(a, b) \
171 1.18.4.1 skrll (((a) + IEEE80211_SEQ_RANGE - (b)) & (IEEE80211_SEQ_RANGE-1))
172 1.18.4.1 skrll
173 1.18.4.1 skrll #define IEEE80211_SEQ_BA_RANGE 2048 /* 2^11 */
174 1.18.4.1 skrll #define IEEE80211_SEQ_BA_BEFORE(a, b) \
175 1.18.4.1 skrll (IEEE80211_SEQ_SUB(b, a+1) < IEEE80211_SEQ_BA_RANGE-1)
176 1.1 dyoung
177 1.1 dyoung #define IEEE80211_NWID_LEN 32
178 1.1 dyoung
179 1.6 dyoung #define IEEE80211_QOS_TXOP 0x00ff
180 1.6 dyoung /* bit 8 is reserved */
181 1.18.4.1 skrll #define IEEE80211_QOS_AMSDU 0x80
182 1.18.4.1 skrll #define IEEE80211_QOS_AMSDU_S 7
183 1.13 dyoung #define IEEE80211_QOS_ACKPOLICY 0x60
184 1.13 dyoung #define IEEE80211_QOS_ACKPOLICY_S 5
185 1.18.4.1 skrll #define IEEE80211_QOS_ACKPOLICY_NOACK 0x20 /* No ACK required */
186 1.18.4.1 skrll #define IEEE80211_QOS_ACKPOLICY_BA 0x60 /* Block ACK */
187 1.13 dyoung #define IEEE80211_QOS_ESOP 0x10
188 1.13 dyoung #define IEEE80211_QOS_ESOP_S 4
189 1.13 dyoung #define IEEE80211_QOS_TID 0x0f
190 1.13 dyoung
191 1.13 dyoung /* does frame have QoS sequence control data */
192 1.13 dyoung #define IEEE80211_QOS_HAS_SEQ(wh) \
193 1.13 dyoung (((wh)->i_fc[0] & \
194 1.13 dyoung (IEEE80211_FC0_TYPE_MASK | IEEE80211_FC0_SUBTYPE_QOS)) == \
195 1.13 dyoung (IEEE80211_FC0_TYPE_DATA | IEEE80211_FC0_SUBTYPE_QOS))
196 1.6 dyoung
197 1.1 dyoung /*
198 1.7 mycroft * WME/802.11e information element.
199 1.7 mycroft */
200 1.13 dyoung struct ieee80211_wme_info {
201 1.18.4.1 skrll uint8_t wme_id; /* IEEE80211_ELEMID_VENDOR */
202 1.18.4.1 skrll uint8_t wme_len; /* length in bytes */
203 1.18.4.1 skrll uint8_t wme_oui[3]; /* 0x00, 0x50, 0xf2 */
204 1.18.4.1 skrll uint8_t wme_type; /* OUI type */
205 1.18.4.1 skrll uint8_t wme_subtype; /* OUI subtype */
206 1.18.4.1 skrll uint8_t wme_version; /* spec revision */
207 1.18.4.1 skrll uint8_t wme_info; /* QoS info */
208 1.13 dyoung } __packed;
209 1.7 mycroft
210 1.7 mycroft /*
211 1.7 mycroft * WME/802.11e Tspec Element
212 1.7 mycroft */
213 1.7 mycroft struct ieee80211_wme_tspec {
214 1.18.4.1 skrll uint8_t ts_id;
215 1.18.4.1 skrll uint8_t ts_len;
216 1.18.4.1 skrll uint8_t ts_oui[3];
217 1.18.4.1 skrll uint8_t ts_oui_type;
218 1.18.4.1 skrll uint8_t ts_oui_subtype;
219 1.18.4.1 skrll uint8_t ts_version;
220 1.18.4.1 skrll uint8_t ts_tsinfo[3];
221 1.18.4.1 skrll uint8_t ts_nom_msdu[2];
222 1.18.4.1 skrll uint8_t ts_max_msdu[2];
223 1.18.4.1 skrll uint8_t ts_min_svc[4];
224 1.18.4.1 skrll uint8_t ts_max_svc[4];
225 1.18.4.1 skrll uint8_t ts_inactv_intv[4];
226 1.18.4.1 skrll uint8_t ts_susp_intv[4];
227 1.18.4.1 skrll uint8_t ts_start_svc[4];
228 1.18.4.1 skrll uint8_t ts_min_rate[4];
229 1.18.4.1 skrll uint8_t ts_mean_rate[4];
230 1.18.4.1 skrll uint8_t ts_max_burst[4];
231 1.18.4.1 skrll uint8_t ts_min_phy[4];
232 1.18.4.1 skrll uint8_t ts_peak_rate[4];
233 1.18.4.1 skrll uint8_t ts_delay[4];
234 1.18.4.1 skrll uint8_t ts_surplus[2];
235 1.18.4.1 skrll uint8_t ts_medium_time[2];
236 1.13 dyoung } __packed;
237 1.13 dyoung
238 1.13 dyoung /*
239 1.13 dyoung * WME AC parameter field
240 1.13 dyoung */
241 1.13 dyoung struct ieee80211_wme_acparams {
242 1.18.4.1 skrll uint8_t acp_aci_aifsn;
243 1.18.4.1 skrll uint8_t acp_logcwminmax;
244 1.18.4.1 skrll uint16_t acp_txop;
245 1.13 dyoung } __packed;
246 1.13 dyoung
247 1.13 dyoung #define WME_NUM_AC 4 /* 4 AC categories */
248 1.18.4.1 skrll #define WME_NUM_TID 16 /* 16 tids */
249 1.13 dyoung
250 1.13 dyoung #define WME_PARAM_ACI 0x60 /* Mask for ACI field */
251 1.13 dyoung #define WME_PARAM_ACI_S 5 /* Shift for ACI field */
252 1.13 dyoung #define WME_PARAM_ACM 0x10 /* Mask for ACM bit */
253 1.13 dyoung #define WME_PARAM_ACM_S 4 /* Shift for ACM bit */
254 1.13 dyoung #define WME_PARAM_AIFSN 0x0f /* Mask for aifsn field */
255 1.13 dyoung #define WME_PARAM_AIFSN_S 0 /* Shift for aifsn field */
256 1.13 dyoung #define WME_PARAM_LOGCWMIN 0x0f /* Mask for CwMin field (in log) */
257 1.13 dyoung #define WME_PARAM_LOGCWMIN_S 0 /* Shift for CwMin field */
258 1.13 dyoung #define WME_PARAM_LOGCWMAX 0xf0 /* Mask for CwMax field (in log) */
259 1.13 dyoung #define WME_PARAM_LOGCWMAX_S 4 /* Shift for CwMax field */
260 1.13 dyoung
261 1.13 dyoung #define WME_AC_TO_TID(_ac) ( \
262 1.13 dyoung ((_ac) == WME_AC_VO) ? 6 : \
263 1.13 dyoung ((_ac) == WME_AC_VI) ? 5 : \
264 1.13 dyoung ((_ac) == WME_AC_BK) ? 1 : \
265 1.13 dyoung 0)
266 1.13 dyoung
267 1.13 dyoung #define TID_TO_WME_AC(_tid) ( \
268 1.18.4.1 skrll ((_tid) == 0 || (_tid) == 3) ? WME_AC_BE : \
269 1.13 dyoung ((_tid) < 3) ? WME_AC_BK : \
270 1.13 dyoung ((_tid) < 6) ? WME_AC_VI : \
271 1.13 dyoung WME_AC_VO)
272 1.13 dyoung
273 1.13 dyoung /*
274 1.13 dyoung * WME Parameter Element
275 1.13 dyoung */
276 1.13 dyoung struct ieee80211_wme_param {
277 1.18.4.1 skrll uint8_t param_id;
278 1.18.4.1 skrll uint8_t param_len;
279 1.18.4.1 skrll uint8_t param_oui[3];
280 1.18.4.1 skrll uint8_t param_oui_type;
281 1.18.4.1 skrll uint8_t param_oui_subtype;
282 1.18.4.1 skrll uint8_t param_version;
283 1.18.4.1 skrll uint8_t param_qosInfo;
284 1.13 dyoung #define WME_QOSINFO_COUNT 0x0f /* Mask for param count field */
285 1.18.4.1 skrll uint8_t param_reserved;
286 1.13 dyoung struct ieee80211_wme_acparams params_acParams[WME_NUM_AC];
287 1.13 dyoung } __packed;
288 1.7 mycroft
289 1.7 mycroft /*
290 1.7 mycroft * Management Notification Frame
291 1.7 mycroft */
292 1.7 mycroft struct ieee80211_mnf {
293 1.18.4.1 skrll uint8_t mnf_category;
294 1.18.4.1 skrll uint8_t mnf_action;
295 1.18.4.1 skrll uint8_t mnf_dialog;
296 1.18.4.1 skrll uint8_t mnf_status;
297 1.13 dyoung } __packed;
298 1.7 mycroft #define MNF_SETUP_REQ 0
299 1.7 mycroft #define MNF_SETUP_RESP 1
300 1.7 mycroft #define MNF_TEARDOWN 2
301 1.7 mycroft
302 1.18.4.1 skrll /*
303 1.18.4.1 skrll * 802.11n Management Action Frames
304 1.18.4.1 skrll */
305 1.18.4.1 skrll /* generic frame format */
306 1.18.4.1 skrll struct ieee80211_action {
307 1.18.4.1 skrll uint8_t ia_category;
308 1.18.4.1 skrll uint8_t ia_action;
309 1.18.4.1 skrll } __packed;
310 1.18.4.1 skrll
311 1.18.4.1 skrll #define IEEE80211_ACTION_CAT_QOS 0 /* QoS */
312 1.18.4.1 skrll #define IEEE80211_ACTION_CAT_BA 3 /* BA */
313 1.18.4.1 skrll #define IEEE80211_ACTION_CAT_HT 7 /* HT */
314 1.18.4.1 skrll
315 1.18.4.1 skrll #define IEEE80211_ACTION_HT_TXCHWIDTH 0 /* recommended xmit chan width*/
316 1.18.4.1 skrll #define IEEE80211_ACTION_HT_MIMOPWRSAVE 1 /* MIMO power save */
317 1.18.4.1 skrll
318 1.18.4.1 skrll /* HT - recommended transmission channel width */
319 1.18.4.1 skrll struct ieee80211_action_ht_txchwidth {
320 1.18.4.1 skrll struct ieee80211_action at_header;
321 1.18.4.1 skrll uint8_t at_chwidth;
322 1.18.4.1 skrll } __packed;
323 1.18.4.1 skrll
324 1.18.4.1 skrll #define IEEE80211_A_HT_TXCHWIDTH_20 0
325 1.18.4.1 skrll #define IEEE80211_A_HT_TXCHWIDTH_2040 1
326 1.18.4.1 skrll
327 1.18.4.1 skrll /* HT - MIMO Power Save (NB: D2.04) */
328 1.18.4.1 skrll struct ieee80211_action_ht_mimopowersave {
329 1.18.4.1 skrll struct ieee80211_action am_header;
330 1.18.4.1 skrll uint8_t am_control;
331 1.18.4.1 skrll } __packed;
332 1.18.4.1 skrll
333 1.18.4.1 skrll #define IEEE80211_A_HT_MIMOPWRSAVE_ENA 0x01 /* PS enabled */
334 1.18.4.1 skrll #define IEEE80211_A_HT_MIMOPWRSAVE_MODE 0x02
335 1.18.4.1 skrll #define IEEE80211_A_HT_MIMOPWRSAVE_MODE_S 1
336 1.18.4.1 skrll #define IEEE80211_A_HT_MIMOPWRSAVE_DYNAMIC 0x02 /* Dynamic Mode */
337 1.18.4.1 skrll #define IEEE80211_A_HT_MIMOPWRSAVE_STATIC 0x00 /* no SM packets */
338 1.18.4.1 skrll /* bits 2-7 reserved */
339 1.18.4.1 skrll
340 1.18.4.1 skrll /* Block Ack actions */
341 1.18.4.1 skrll #define IEEE80211_ACTION_BA_ADDBA_REQUEST 0 /* ADDBA request */
342 1.18.4.1 skrll #define IEEE80211_ACTION_BA_ADDBA_RESPONSE 1 /* ADDBA response */
343 1.18.4.1 skrll #define IEEE80211_ACTION_BA_DELBA 2 /* DELBA */
344 1.18.4.1 skrll
345 1.18.4.1 skrll /* Block Ack Parameter Set */
346 1.18.4.1 skrll #define IEEE80211_BAPS_BUFSIZ 0xffc0 /* buffer size */
347 1.18.4.1 skrll #define IEEE80211_BAPS_BUFSIZ_S 6
348 1.18.4.1 skrll #define IEEE80211_BAPS_TID 0x003c /* TID */
349 1.18.4.1 skrll #define IEEE80211_BAPS_TID_S 2
350 1.18.4.1 skrll #define IEEE80211_BAPS_POLICY 0x0002 /* block ack policy */
351 1.18.4.1 skrll #define IEEE80211_BAPS_POLICY_S 1
352 1.18.4.1 skrll
353 1.18.4.1 skrll #define IEEE80211_BAPS_POLICY_DELAYED (0<<IEEE80211_BAPS_POLICY_S)
354 1.18.4.1 skrll #define IEEE80211_BAPS_POLICY_IMMEDIATE (1<<IEEE80211_BAPS_POLICY_S)
355 1.18.4.1 skrll
356 1.18.4.1 skrll /* Block Ack Sequence Control */
357 1.18.4.1 skrll #define IEEE80211_BASEQ_START 0xfff0 /* starting seqnum */
358 1.18.4.1 skrll #define IEEE80211_BASEQ_START_S 4
359 1.18.4.1 skrll #define IEEE80211_BASEQ_FRAG 0x000f /* fragment number */
360 1.18.4.1 skrll #define IEEE80211_BASEQ_FRAG_S 0
361 1.18.4.1 skrll
362 1.18.4.1 skrll /* Delayed Block Ack Parameter Set */
363 1.18.4.1 skrll #define IEEE80211_DELBAPS_TID 0xf000 /* TID */
364 1.18.4.1 skrll #define IEEE80211_DELBAPS_TID_S 12
365 1.18.4.1 skrll #define IEEE80211_DELBAPS_INIT 0x0800 /* initiator */
366 1.18.4.1 skrll #define IEEE80211_DELBAPS_INIT_S 11
367 1.18.4.1 skrll
368 1.18.4.1 skrll /* BA - ADDBA request */
369 1.18.4.1 skrll struct ieee80211_action_ba_addbarequest {
370 1.18.4.1 skrll struct ieee80211_action rq_header;
371 1.18.4.1 skrll uint8_t rq_dialogtoken;
372 1.18.4.1 skrll uint16_t rq_baparamset;
373 1.18.4.1 skrll uint16_t rq_batimeout; /* in TUs */
374 1.18.4.1 skrll uint16_t rq_baseqctl;
375 1.18.4.1 skrll } __packed;
376 1.18.4.1 skrll
377 1.18.4.1 skrll /* BA - ADDBA response */
378 1.18.4.1 skrll struct ieee80211_action_ba_addbaresponse {
379 1.18.4.1 skrll struct ieee80211_action rs_header;
380 1.18.4.1 skrll uint8_t rs_dialogtoken;
381 1.18.4.1 skrll uint16_t rs_statuscode;
382 1.18.4.1 skrll uint16_t rs_baparamset;
383 1.18.4.1 skrll uint16_t rs_batimeout; /* in TUs */
384 1.18.4.1 skrll } __packed;
385 1.18.4.1 skrll
386 1.18.4.1 skrll /* BA - DELBA */
387 1.18.4.1 skrll struct ieee80211_action_ba_delba {
388 1.18.4.1 skrll struct ieee80211_action dl_header;
389 1.18.4.1 skrll uint16_t dl_baparamset;
390 1.18.4.1 skrll uint16_t dl_reasoncode;
391 1.18.4.1 skrll } __packed;
392 1.18.4.1 skrll
393 1.18.4.1 skrll /* BAR Control */
394 1.18.4.1 skrll #define IEEE80211_BAR_TID 0xf000 /* TID */
395 1.18.4.1 skrll #define IEEE80211_BAR_TID_S 12
396 1.18.4.1 skrll #define IEEE80211_BAR_COMP 0x0004 /* compressed */
397 1.18.4.1 skrll #define IEEE80211_BAR_MTID 0x0002
398 1.18.4.1 skrll #define IEEE80211_BAR_NOACK 0x0001 /* no-ack policy */
399 1.18.4.1 skrll
400 1.18.4.1 skrll struct ieee80211_ba_request {
401 1.18.4.1 skrll uint16_t rq_barctl;
402 1.18.4.1 skrll uint16_t rq_barseqctl;
403 1.18.4.1 skrll } __packed;
404 1.18.4.1 skrll
405 1.7 mycroft /*
406 1.5 dyoung * Control frames.
407 1.5 dyoung */
408 1.5 dyoung struct ieee80211_frame_min {
409 1.18.4.1 skrll uint8_t i_fc[2];
410 1.18.4.1 skrll uint8_t i_dur[2];
411 1.18.4.1 skrll uint8_t i_addr1[IEEE80211_ADDR_LEN];
412 1.18.4.1 skrll uint8_t i_addr2[IEEE80211_ADDR_LEN];
413 1.5 dyoung /* FCS */
414 1.13 dyoung } __packed;
415 1.5 dyoung
416 1.5 dyoung struct ieee80211_frame_rts {
417 1.18.4.1 skrll uint8_t i_fc[2];
418 1.18.4.1 skrll uint8_t i_dur[2];
419 1.18.4.1 skrll uint8_t i_ra[IEEE80211_ADDR_LEN];
420 1.18.4.1 skrll uint8_t i_ta[IEEE80211_ADDR_LEN];
421 1.5 dyoung /* FCS */
422 1.13 dyoung } __packed;
423 1.5 dyoung
424 1.5 dyoung struct ieee80211_frame_cts {
425 1.18.4.1 skrll uint8_t i_fc[2];
426 1.18.4.1 skrll uint8_t i_dur[2];
427 1.18.4.1 skrll uint8_t i_ra[IEEE80211_ADDR_LEN];
428 1.5 dyoung /* FCS */
429 1.13 dyoung } __packed;
430 1.5 dyoung
431 1.5 dyoung struct ieee80211_frame_ack {
432 1.18.4.1 skrll uint8_t i_fc[2];
433 1.18.4.1 skrll uint8_t i_dur[2];
434 1.18.4.1 skrll uint8_t i_ra[IEEE80211_ADDR_LEN];
435 1.5 dyoung /* FCS */
436 1.13 dyoung } __packed;
437 1.5 dyoung
438 1.5 dyoung struct ieee80211_frame_pspoll {
439 1.18.4.1 skrll uint8_t i_fc[2];
440 1.18.4.1 skrll uint8_t i_aid[2];
441 1.18.4.1 skrll uint8_t i_bssid[IEEE80211_ADDR_LEN];
442 1.18.4.1 skrll uint8_t i_ta[IEEE80211_ADDR_LEN];
443 1.5 dyoung /* FCS */
444 1.13 dyoung } __packed;
445 1.5 dyoung
446 1.5 dyoung struct ieee80211_frame_cfend { /* NB: also CF-End+CF-Ack */
447 1.18.4.1 skrll uint8_t i_fc[2];
448 1.18.4.1 skrll uint8_t i_dur[2]; /* should be zero */
449 1.18.4.1 skrll uint8_t i_ra[IEEE80211_ADDR_LEN];
450 1.18.4.1 skrll uint8_t i_bssid[IEEE80211_ADDR_LEN];
451 1.18.4.1 skrll /* FCS */
452 1.18.4.1 skrll } __packed;
453 1.18.4.1 skrll
454 1.18.4.1 skrll struct ieee80211_frame_bar {
455 1.18.4.1 skrll uint8_t i_fc[2];
456 1.18.4.1 skrll uint8_t i_dur[2];
457 1.18.4.1 skrll uint8_t i_ra[IEEE80211_ADDR_LEN];
458 1.18.4.1 skrll uint8_t i_ta[IEEE80211_ADDR_LEN];
459 1.18.4.1 skrll uint16_t i_ctl;
460 1.18.4.1 skrll uint16_t i_seq;
461 1.5 dyoung /* FCS */
462 1.13 dyoung } __packed;
463 1.5 dyoung
464 1.5 dyoung /*
465 1.1 dyoung * BEACON management packets
466 1.1 dyoung *
467 1.1 dyoung * octet timestamp[8]
468 1.1 dyoung * octet beacon interval[2]
469 1.1 dyoung * octet capability information[2]
470 1.1 dyoung * information element
471 1.1 dyoung * octet elemid
472 1.1 dyoung * octet length
473 1.1 dyoung * octet information[length]
474 1.1 dyoung */
475 1.1 dyoung
476 1.1 dyoung #define IEEE80211_BEACON_INTERVAL(beacon) \
477 1.1 dyoung ((beacon)[8] | ((beacon)[9] << 8))
478 1.1 dyoung #define IEEE80211_BEACON_CAPABILITY(beacon) \
479 1.1 dyoung ((beacon)[10] | ((beacon)[11] << 8))
480 1.1 dyoung
481 1.1 dyoung #define IEEE80211_CAPINFO_ESS 0x0001
482 1.1 dyoung #define IEEE80211_CAPINFO_IBSS 0x0002
483 1.1 dyoung #define IEEE80211_CAPINFO_CF_POLLABLE 0x0004
484 1.1 dyoung #define IEEE80211_CAPINFO_CF_POLLREQ 0x0008
485 1.1 dyoung #define IEEE80211_CAPINFO_PRIVACY 0x0010
486 1.1 dyoung #define IEEE80211_CAPINFO_SHORT_PREAMBLE 0x0020
487 1.1 dyoung #define IEEE80211_CAPINFO_PBCC 0x0040
488 1.1 dyoung #define IEEE80211_CAPINFO_CHNL_AGILITY 0x0080
489 1.18.4.1 skrll #define IEEE80211_CAPINFO_SPECTRUM_MGMT 0x0100
490 1.18.4.1 skrll /* bit 9 is reserved */
491 1.1 dyoung #define IEEE80211_CAPINFO_SHORT_SLOTTIME 0x0400
492 1.6 dyoung #define IEEE80211_CAPINFO_RSN 0x0800
493 1.6 dyoung /* bit 12 is reserved */
494 1.1 dyoung #define IEEE80211_CAPINFO_DSSSOFDM 0x2000
495 1.1 dyoung /* bits 14-15 are reserved */
496 1.1 dyoung
497 1.1 dyoung /*
498 1.6 dyoung * 802.11i/WPA information element (maximally sized).
499 1.6 dyoung */
500 1.6 dyoung struct ieee80211_ie_wpa {
501 1.18.4.1 skrll uint8_t wpa_id; /* IEEE80211_ELEMID_VENDOR */
502 1.18.4.1 skrll uint8_t wpa_len; /* length in bytes */
503 1.18.4.1 skrll uint8_t wpa_oui[3]; /* 0x00, 0x50, 0xf2 */
504 1.18.4.1 skrll uint8_t wpa_type; /* OUI type */
505 1.18.4.1 skrll uint16_t wpa_version; /* spec revision */
506 1.18.4.1 skrll uint32_t wpa_mcipher[1]; /* multicast/group key cipher */
507 1.18.4.1 skrll uint16_t wpa_uciphercnt; /* # pairwise key ciphers */
508 1.18.4.1 skrll uint32_t wpa_uciphers[8];/* ciphers */
509 1.18.4.1 skrll uint16_t wpa_authselcnt; /* authentication selector cnt*/
510 1.18.4.1 skrll uint32_t wpa_authsels[8];/* selectors */
511 1.18.4.1 skrll uint16_t wpa_caps; /* 802.11i capabilities */
512 1.18.4.1 skrll uint16_t wpa_pmkidcnt; /* 802.11i pmkid count */
513 1.18.4.1 skrll uint16_t wpa_pmkids[8]; /* 802.11i pmkids */
514 1.18.4.1 skrll } __packed;
515 1.18.4.1 skrll
516 1.18.4.1 skrll /*
517 1.18.4.1 skrll * 802.11n HT Capability IE
518 1.18.4.1 skrll * NB: these reflect D1.10
519 1.18.4.1 skrll */
520 1.18.4.1 skrll struct ieee80211_ie_htcap {
521 1.18.4.1 skrll uint8_t hc_id; /* element ID */
522 1.18.4.1 skrll uint8_t hc_len; /* length in bytes */
523 1.18.4.1 skrll uint16_t hc_cap; /* HT caps (see below) */
524 1.18.4.1 skrll uint8_t hc_param; /* HT params (see below) */
525 1.18.4.1 skrll uint8_t hc_mcsset[16]; /* supported MCS set */
526 1.18.4.1 skrll uint16_t hc_extcap; /* extended HT capabilities */
527 1.18.4.1 skrll uint32_t hc_txbf; /* txbf capabilities */
528 1.18.4.1 skrll uint8_t hc_antenna; /* antenna capabilities */
529 1.18.4.1 skrll } __packed;
530 1.18.4.1 skrll
531 1.18.4.1 skrll /* HT capability flags (ht_cap) */
532 1.18.4.1 skrll #define IEEE80211_HTCAP_LDPC 0x0001 /* LDPC supported */
533 1.18.4.1 skrll #define IEEE80211_HTCAP_CHWIDTH40 0x0002 /* 20/40 supported */
534 1.18.4.1 skrll #define IEEE80211_HTCAP_SMPS 0x000c /* SM Power Save mode */
535 1.18.4.1 skrll #define IEEE80211_HTCAP_SMPS_OFF 0x0000 /* none (static mode) */
536 1.18.4.1 skrll #define IEEE80211_HTCAP_SMPS_DYNAMIC 0x0004 /* send RTS first */
537 1.18.4.1 skrll /* NB: SMPS value 2 is reserved */
538 1.18.4.1 skrll #define IEEE80211_HTCAP_SMPS_ENA 0x000c /* enabled */
539 1.18.4.1 skrll #define IEEE80211_HTCAP_GREENFIELD 0x0010 /* Greenfield supported */
540 1.18.4.1 skrll #define IEEE80211_HTCAP_SHORTGI20 0x0020 /* Short GI in 20MHz */
541 1.18.4.1 skrll #define IEEE80211_HTCAP_SHORTGI40 0x0040 /* Short GI in 40MHz */
542 1.18.4.1 skrll #define IEEE80211_HTCAP_TXSTBC 0x0080 /* STBC tx ok */
543 1.18.4.1 skrll #define IEEE80211_HTCAP_RXSTBC 0x0300 /* STBC rx support */
544 1.18.4.1 skrll #define IEEE80211_HTCAP_RXSTBC_S 8
545 1.18.4.1 skrll #define IEEE80211_HTCAP_RXSTBC_1STREAM 0x0100 /* 1 spatial stream */
546 1.18.4.1 skrll #define IEEE80211_HTCAP_RXSTBC_2STREAM 0x0200 /* 1-2 spatial streams*/
547 1.18.4.1 skrll #define IEEE80211_HTCAP_RXSTBC_3STREAM 0x0300 /* 1-3 spatial streams*/
548 1.18.4.1 skrll #define IEEE80211_HTCAP_DELBA 0x0400 /* HT DELBA supported */
549 1.18.4.1 skrll #define IEEE80211_HTCAP_MAXAMSDU 0x0800 /* max A-MSDU length */
550 1.18.4.1 skrll #define IEEE80211_HTCAP_MAXAMSDU_7935 0x0800 /* 7935 octets */
551 1.18.4.1 skrll #define IEEE80211_HTCAP_MAXAMSDU_3839 0x0000 /* 3839 octets */
552 1.18.4.1 skrll #define IEEE80211_HTCAP_DSSSCCK40 0x1000 /* DSSS/CCK in 40MHz */
553 1.18.4.1 skrll #define IEEE80211_HTCAP_PSMP 0x2000 /* PSMP supported */
554 1.18.4.1 skrll #define IEEE80211_HTCAP_40INTOLERANT 0x4000 /* 40MHz intolerant */
555 1.18.4.1 skrll #define IEEE80211_HTCAP_LSIGTXOPPROT 0x8000 /* L-SIG TXOP prot */
556 1.18.4.1 skrll
557 1.18.4.1 skrll /* HT parameters (hc_param) */
558 1.18.4.1 skrll #define IEEE80211_HTCAP_MAXRXAMPDU 0x03 /* max rx A-MPDU factor */
559 1.18.4.1 skrll #define IEEE80211_HTCAP_MAXRXAMPDU_S 0
560 1.18.4.1 skrll #define IEEE80211_HTCAP_MAXRXAMPDU_8K 0
561 1.18.4.1 skrll #define IEEE80211_HTCAP_MAXRXAMPDU_16K 1
562 1.18.4.1 skrll #define IEEE80211_HTCAP_MAXRXAMPDU_32K 2
563 1.18.4.1 skrll #define IEEE80211_HTCAP_MAXRXAMPDU_64K 3
564 1.18.4.1 skrll #define IEEE80211_HTCAP_MPDUDENSITY 0x1c /* min MPDU start spacing */
565 1.18.4.1 skrll #define IEEE80211_HTCAP_MPDUDENSITY_S 2
566 1.18.4.1 skrll #define IEEE80211_HTCAP_MPDUDENSITY_NA 0 /* no time restriction */
567 1.18.4.1 skrll #define IEEE80211_HTCAP_MPDUDENSITY_025 1 /* 1/4 us */
568 1.18.4.1 skrll #define IEEE80211_HTCAP_MPDUDENSITY_05 2 /* 1/2 us */
569 1.18.4.1 skrll #define IEEE80211_HTCAP_MPDUDENSITY_1 3 /* 1 us */
570 1.18.4.1 skrll #define IEEE80211_HTCAP_MPDUDENSITY_2 4 /* 2 us */
571 1.18.4.1 skrll #define IEEE80211_HTCAP_MPDUDENSITY_4 5 /* 4 us */
572 1.18.4.1 skrll #define IEEE80211_HTCAP_MPDUDENSITY_8 6 /* 8 us */
573 1.18.4.1 skrll #define IEEE80211_HTCAP_MPDUDENSITY_16 7 /* 16 us */
574 1.18.4.1 skrll
575 1.18.4.1 skrll /* HT extended capabilities (hc_extcap) */
576 1.18.4.1 skrll #define IEEE80211_HTCAP_PCO 0x0001 /* PCO capable */
577 1.18.4.1 skrll #define IEEE80211_HTCAP_PCOTRANS 0x0006 /* PCO transition time */
578 1.18.4.1 skrll #define IEEE80211_HTCAP_PCOTRANS_S 1
579 1.18.4.1 skrll #define IEEE80211_HTCAP_PCOTRANS_04 0x0002 /* 400 us */
580 1.18.4.1 skrll #define IEEE80211_HTCAP_PCOTRANS_15 0x0004 /* 1.5 ms */
581 1.18.4.1 skrll #define IEEE80211_HTCAP_PCOTRANS_5 0x0006 /* 5 ms */
582 1.18.4.1 skrll /* bits 3-7 reserved */
583 1.18.4.1 skrll #define IEEE80211_HTCAP_MCSFBACK 0x0300 /* MCS feedback */
584 1.18.4.1 skrll #define IEEE80211_HTCAP_MCSFBACK_S 8
585 1.18.4.1 skrll #define IEEE80211_HTCAP_MCSFBACK_NONE 0x0000 /* nothing provided */
586 1.18.4.1 skrll #define IEEE80211_HTCAP_MCSFBACK_UNSOL 0x0200 /* unsolicited feedback */
587 1.18.4.1 skrll #define IEEE80211_HTCAP_MCSFBACK_MRQ 0x0300 /* " "+respond to MRQ */
588 1.18.4.1 skrll #define IEEE80211_HTCAP_HTC 0x0400 /* +HTC support */
589 1.18.4.1 skrll #define IEEE80211_HTCAP_RDR 0x0800 /* reverse direction responder*/
590 1.18.4.1 skrll /* bits 12-15 reserved */
591 1.18.4.1 skrll
592 1.18.4.1 skrll /*
593 1.18.4.1 skrll * 802.11n HT Information IE
594 1.18.4.1 skrll */
595 1.18.4.1 skrll struct ieee80211_ie_htinfo {
596 1.18.4.1 skrll uint8_t hi_id; /* element ID */
597 1.18.4.1 skrll uint8_t hi_len; /* length in bytes */
598 1.18.4.1 skrll uint8_t hi_ctrlchannel; /* primary channel */
599 1.18.4.1 skrll uint8_t hi_byte1; /* ht ie byte 1 */
600 1.18.4.1 skrll uint8_t hi_byte2; /* ht ie byte 2 */
601 1.18.4.1 skrll uint8_t hi_byte3; /* ht ie byte 3 */
602 1.18.4.1 skrll uint16_t hi_byte45; /* ht ie bytes 4+5 */
603 1.18.4.1 skrll uint8_t hi_basicmcsset[16]; /* basic MCS set */
604 1.13 dyoung } __packed;
605 1.6 dyoung
606 1.18.4.1 skrll /* byte1 */
607 1.18.4.1 skrll #define IEEE80211_HTINFO_2NDCHAN 0x03 /* secondary/ext chan offset */
608 1.18.4.1 skrll #define IEEE80211_HTINFO_2NDCHAN_S 0
609 1.18.4.1 skrll #define IEEE80211_HTINFO_2NDCHAN_NONE 0x00 /* no secondary/ext channel */
610 1.18.4.1 skrll #define IEEE80211_HTINFO_2NDCHAN_ABOVE 0x01 /* above private channel */
611 1.18.4.1 skrll /* NB: 2 is reserved */
612 1.18.4.1 skrll #define IEEE80211_HTINFO_2NDCHAN_BELOW 0x03 /* below primary channel */
613 1.18.4.1 skrll #define IEEE80211_HTINFO_TXWIDTH 0x04 /* tx channel width */
614 1.18.4.1 skrll #define IEEE80211_HTINFO_TXWIDTH_20 0x00 /* 20MHz width */
615 1.18.4.1 skrll #define IEEE80211_HTINFO_TXWIDTH_2040 0x04 /* any supported width */
616 1.18.4.1 skrll #define IEEE80211_HTINFO_RIFSMODE 0x08 /* Reduced IFS (RIFS) use */
617 1.18.4.1 skrll #define IEEE80211_HTINFO_RIFSMODE_PROH 0x00 /* RIFS use prohibited */
618 1.18.4.1 skrll #define IEEE80211_HTINFO_RIFSMODE_PERM 0x08 /* RIFS use permitted */
619 1.18.4.1 skrll #define IEEE80211_HTINFO_PMSPONLY 0x10 /* PSMP required to associate */
620 1.18.4.1 skrll #define IEEE80211_HTINFO_SIGRAN 0xe0 /* shortest Service Interval */
621 1.18.4.1 skrll #define IEEE80211_HTINFO_SIGRAN_S 5
622 1.18.4.1 skrll #define IEEE80211_HTINFO_SIGRAN_5 0x00 /* 5 ms */
623 1.18.4.1 skrll /* XXX add rest */
624 1.18.4.1 skrll
625 1.18.4.1 skrll /* bytes 2+3 */
626 1.18.4.1 skrll #define IEEE80211_HTINFO_OPMODE 0x03 /* operating mode */
627 1.18.4.1 skrll #define IEEE80211_HTINFO_OPMODE_S 0
628 1.18.4.1 skrll #define IEEE80211_HTINFO_OPMODE_PURE 0x00 /* no protection */
629 1.18.4.1 skrll #define IEEE80211_HTINFO_OPMODE_PROTOPT 0x01 /* protection optional */
630 1.18.4.1 skrll #define IEEE80211_HTINFO_OPMODE_HT20PR 0x02 /* protection for HT20 sta's */
631 1.18.4.1 skrll #define IEEE80211_HTINFO_OPMODE_MIXED 0x03 /* protection for legacy sta's*/
632 1.18.4.1 skrll #define IEEE80211_HTINFO_NONGF_PRESENT 0x04 /* non-GF sta's present */
633 1.18.4.1 skrll #define IEEE80211_HTINFO_TXBL 0x08 /* transmit burst limit */
634 1.18.4.1 skrll #define IEEE80211_HTINFO_NONHT_PRESENT 0x10 /* non-HT sta's present */
635 1.18.4.1 skrll /* bits 5-15 reserved */
636 1.18.4.1 skrll
637 1.18.4.1 skrll /* bytes 4+5 */
638 1.18.4.1 skrll #define IEEE80211_HTINFO_2NDARYBEACON 0x01
639 1.18.4.1 skrll #define IEEE80211_HTINFO_LSIGTXOPPROT 0x02
640 1.18.4.1 skrll #define IEEE80211_HTINFO_PCO_ACTIVE 0x04
641 1.18.4.1 skrll #define IEEE80211_HTINFO_40MHZPHASE 0x08
642 1.18.4.1 skrll
643 1.18.4.1 skrll /* byte5 */
644 1.18.4.1 skrll #define IEEE80211_HTINFO_BASIC_STBCMCS 0x7f
645 1.18.4.1 skrll #define IEEE80211_HTINFO_BASIC_STBCMCS_S 0
646 1.18.4.1 skrll #define IEEE80211_HTINFO_DUALPROTECTED 0x80
647 1.18.4.1 skrll
648 1.6 dyoung /*
649 1.13 dyoung * Management information element payloads.
650 1.1 dyoung */
651 1.1 dyoung
652 1.1 dyoung enum {
653 1.7 mycroft IEEE80211_ELEMID_SSID = 0,
654 1.7 mycroft IEEE80211_ELEMID_RATES = 1,
655 1.7 mycroft IEEE80211_ELEMID_FHPARMS = 2,
656 1.7 mycroft IEEE80211_ELEMID_DSPARMS = 3,
657 1.7 mycroft IEEE80211_ELEMID_CFPARMS = 4,
658 1.7 mycroft IEEE80211_ELEMID_TIM = 5,
659 1.7 mycroft IEEE80211_ELEMID_IBSSPARMS = 6,
660 1.7 mycroft IEEE80211_ELEMID_COUNTRY = 7,
661 1.7 mycroft IEEE80211_ELEMID_CHALLENGE = 16,
662 1.6 dyoung /* 17-31 reserved for challenge text extension */
663 1.18 degroote IEEE80211_ELEMID_PWRCNSTR = 32,
664 1.18 degroote IEEE80211_ELEMID_PWRCAP = 33,
665 1.18 degroote IEEE80211_ELEMID_TPCREQ = 34,
666 1.18 degroote IEEE80211_ELEMID_TPCREP = 35,
667 1.18 degroote IEEE80211_ELEMID_SUPPCHAN = 36,
668 1.18 degroote IEEE80211_ELEMID_CHANSWITCHANN = 37,
669 1.18 degroote IEEE80211_ELEMID_MEASREQ = 38,
670 1.18 degroote IEEE80211_ELEMID_MEASREP = 39,
671 1.18 degroote IEEE80211_ELEMID_QUIET = 40,
672 1.18 degroote IEEE80211_ELEMID_IBSSDFS = 41,
673 1.7 mycroft IEEE80211_ELEMID_ERP = 42,
674 1.18 degroote IEEE80211_ELEMID_HTCAP = 45,
675 1.7 mycroft IEEE80211_ELEMID_RSN = 48,
676 1.7 mycroft IEEE80211_ELEMID_XRATES = 50,
677 1.18 degroote IEEE80211_ELEMID_HTINFO = 61,
678 1.7 mycroft IEEE80211_ELEMID_TPC = 150,
679 1.7 mycroft IEEE80211_ELEMID_CCKM = 156,
680 1.7 mycroft IEEE80211_ELEMID_VENDOR = 221, /* vendor private */
681 1.1 dyoung };
682 1.4 dyoung
683 1.13 dyoung struct ieee80211_tim_ie {
684 1.18.4.1 skrll uint8_t tim_ie; /* IEEE80211_ELEMID_TIM */
685 1.18.4.1 skrll uint8_t tim_len;
686 1.18.4.1 skrll uint8_t tim_count; /* DTIM count */
687 1.18.4.1 skrll uint8_t tim_period; /* DTIM period */
688 1.18.4.1 skrll uint8_t tim_bitctl; /* bitmap control */
689 1.18.4.1 skrll uint8_t tim_bitmap[1]; /* variable-length bitmap */
690 1.13 dyoung } __packed;
691 1.13 dyoung
692 1.18.4.1 skrll struct ieee80211_country_ie {
693 1.18.4.1 skrll uint8_t ie; /* IEEE80211_ELEMID_COUNTRY */
694 1.18.4.1 skrll uint8_t len;
695 1.18.4.1 skrll uint8_t cc[3]; /* ISO CC+(I)ndoor/(O)utdoor */
696 1.18.4.1 skrll struct {
697 1.18.4.1 skrll uint8_t schan; /* starting channel */
698 1.18.4.1 skrll uint8_t nchan; /* number channels */
699 1.18.4.1 skrll uint8_t maxtxpwr; /* tx power cap */
700 1.18.4.1 skrll } __packed band[10]; /* sub bands */
701 1.17 dyoung } __packed;
702 1.17 dyoung
703 1.18.4.1 skrll /*
704 1.18.4.1 skrll * 802.11h Channel Switch Announcement (CSA).
705 1.18.4.1 skrll */
706 1.18.4.1 skrll struct ieee80211_csa_ie {
707 1.18.4.1 skrll uint8_t csa_ie; /* IEEE80211_ELEMID_CHANSWITCHANN */
708 1.18.4.1 skrll uint8_t csa_len;
709 1.18.4.1 skrll uint8_t csa_mode; /* Channel Switch Mode */
710 1.18.4.1 skrll uint8_t csa_newchan; /* New Channel Number */
711 1.18.4.1 skrll uint8_t csa_count; /* Channel Switch Count */
712 1.13 dyoung } __packed;
713 1.13 dyoung
714 1.18.4.1 skrll /*
715 1.18.4.1 skrll * Atheros advanced capability information element.
716 1.18.4.1 skrll */
717 1.18.4.1 skrll struct ieee80211_ath_ie {
718 1.18.4.1 skrll uint8_t ath_id; /* IEEE80211_ELEMID_VENDOR */
719 1.18.4.1 skrll uint8_t ath_len; /* length in bytes */
720 1.18.4.1 skrll uint8_t ath_oui[3]; /* 0x00, 0x03, 0x7f */
721 1.18.4.1 skrll uint8_t ath_oui_type; /* OUI type */
722 1.18.4.1 skrll uint8_t ath_oui_subtype; /* OUI subtype */
723 1.18.4.1 skrll uint8_t ath_version; /* spec revision */
724 1.18.4.1 skrll uint8_t ath_capability; /* capability info */
725 1.18.4.1 skrll #define ATHEROS_CAP_TURBO_PRIME 0x01 /* dynamic turbo--aka Turbo' */
726 1.18.4.1 skrll #define ATHEROS_CAP_COMPRESSION 0x02 /* data compression */
727 1.18.4.1 skrll #define ATHEROS_CAP_FAST_FRAME 0x04 /* fast (jumbo) frames */
728 1.18.4.1 skrll #define ATHEROS_CAP_XR 0x08 /* Xtended Range support */
729 1.18.4.1 skrll #define ATHEROS_CAP_AR 0x10 /* Advanded Radar support */
730 1.18.4.1 skrll #define ATHEROS_CAP_BURST 0x20 /* Bursting - not negotiated */
731 1.18.4.1 skrll #define ATHEROS_CAP_WME 0x40 /* CWMin tuning */
732 1.18.4.1 skrll #define ATHEROS_CAP_BOOST 0x80 /* use turbo/!turbo mode */
733 1.18.4.1 skrll uint8_t ath_defkeyix[2];
734 1.18.4.1 skrll } __packed;
735 1.1 dyoung
736 1.18.4.1 skrll /* rate set entries are in .5 Mb/s units, and potentially marked as basic */
737 1.7 mycroft #define IEEE80211_RATE_BASIC 0x80
738 1.7 mycroft #define IEEE80211_RATE_VAL 0x7f
739 1.1 dyoung
740 1.1 dyoung /* EPR information element flags */
741 1.7 mycroft #define IEEE80211_ERP_NON_ERP_PRESENT 0x01
742 1.7 mycroft #define IEEE80211_ERP_USE_PROTECTION 0x02
743 1.7 mycroft #define IEEE80211_ERP_LONG_PREAMBLE 0x04
744 1.1 dyoung
745 1.18.4.1 skrll #define ATH_OUI 0x7f0300 /* Atheros OUI */
746 1.6 dyoung #define ATH_OUI_TYPE 0x01
747 1.18.4.1 skrll #define ATH_OUI_SUBTYPE 0x01
748 1.18.4.1 skrll #define ATH_OUI_VERSION 0x00
749 1.18.4.1 skrll
750 1.18.4.1 skrll #define BCM_OUI 0x4c9000 /* Broadcom OUI */
751 1.18.4.1 skrll #define BCM_OUI_HTCAP 51 /* pre-draft HTCAP ie */
752 1.18.4.1 skrll #define BCM_OUI_HTINFO 52 /* pre-draft HTINFO ie */
753 1.6 dyoung
754 1.6 dyoung #define WPA_OUI 0xf25000
755 1.6 dyoung #define WPA_OUI_TYPE 0x01
756 1.7 mycroft #define WPA_VERSION 1 /* current supported version */
757 1.6 dyoung
758 1.6 dyoung #define WPA_CSE_NULL 0x00
759 1.6 dyoung #define WPA_CSE_WEP40 0x01
760 1.6 dyoung #define WPA_CSE_TKIP 0x02
761 1.6 dyoung #define WPA_CSE_CCMP 0x04
762 1.6 dyoung #define WPA_CSE_WEP104 0x05
763 1.6 dyoung
764 1.6 dyoung #define WPA_ASE_NONE 0x00
765 1.6 dyoung #define WPA_ASE_8021X_UNSPEC 0x01
766 1.6 dyoung #define WPA_ASE_8021X_PSK 0x02
767 1.6 dyoung
768 1.7 mycroft #define RSN_OUI 0xac0f00
769 1.7 mycroft #define RSN_VERSION 1 /* current supported version */
770 1.7 mycroft
771 1.7 mycroft #define RSN_CSE_NULL 0x00
772 1.7 mycroft #define RSN_CSE_WEP40 0x01
773 1.7 mycroft #define RSN_CSE_TKIP 0x02
774 1.7 mycroft #define RSN_CSE_WRAP 0x03
775 1.7 mycroft #define RSN_CSE_CCMP 0x04
776 1.7 mycroft #define RSN_CSE_WEP104 0x05
777 1.7 mycroft
778 1.7 mycroft #define RSN_ASE_NONE 0x00
779 1.7 mycroft #define RSN_ASE_8021X_UNSPEC 0x01
780 1.7 mycroft #define RSN_ASE_8021X_PSK 0x02
781 1.7 mycroft
782 1.13 dyoung #define RSN_CAP_PREAUTH 0x01
783 1.13 dyoung
784 1.7 mycroft #define WME_OUI 0xf25000
785 1.7 mycroft #define WME_OUI_TYPE 0x02
786 1.13 dyoung #define WME_INFO_OUI_SUBTYPE 0x00
787 1.13 dyoung #define WME_PARAM_OUI_SUBTYPE 0x01
788 1.7 mycroft #define WME_VERSION 1
789 1.7 mycroft
790 1.7 mycroft /* WME stream classes */
791 1.7 mycroft #define WME_AC_BE 0 /* best effort */
792 1.7 mycroft #define WME_AC_BK 1 /* background */
793 1.7 mycroft #define WME_AC_VI 2 /* video */
794 1.7 mycroft #define WME_AC_VO 3 /* voice */
795 1.7 mycroft
796 1.1 dyoung /*
797 1.1 dyoung * AUTH management packets
798 1.1 dyoung *
799 1.1 dyoung * octet algo[2]
800 1.1 dyoung * octet seq[2]
801 1.1 dyoung * octet status[2]
802 1.1 dyoung * octet chal.id
803 1.1 dyoung * octet chal.length
804 1.18.4.1 skrll * octet chal.text[253] NB: 1-253 bytes
805 1.1 dyoung */
806 1.1 dyoung
807 1.18.4.1 skrll /* challenge length for shared key auth */
808 1.18.4.1 skrll #define IEEE80211_CHALLENGE_LEN 128
809 1.1 dyoung
810 1.7 mycroft #define IEEE80211_AUTH_ALG_OPEN 0x0000
811 1.7 mycroft #define IEEE80211_AUTH_ALG_SHARED 0x0001
812 1.7 mycroft #define IEEE80211_AUTH_ALG_LEAP 0x0080
813 1.1 dyoung
814 1.1 dyoung enum {
815 1.1 dyoung IEEE80211_AUTH_OPEN_REQUEST = 1,
816 1.1 dyoung IEEE80211_AUTH_OPEN_RESPONSE = 2,
817 1.1 dyoung };
818 1.1 dyoung
819 1.1 dyoung enum {
820 1.1 dyoung IEEE80211_AUTH_SHARED_REQUEST = 1,
821 1.1 dyoung IEEE80211_AUTH_SHARED_CHALLENGE = 2,
822 1.1 dyoung IEEE80211_AUTH_SHARED_RESPONSE = 3,
823 1.1 dyoung IEEE80211_AUTH_SHARED_PASS = 4,
824 1.1 dyoung };
825 1.1 dyoung
826 1.1 dyoung /*
827 1.18.4.1 skrll * Reason and status codes.
828 1.18.4.1 skrll *
829 1.18.4.1 skrll * Reason codes are used in management frames to indicate why an
830 1.18.4.1 skrll * action took place (e.g. on disassociation). Status codes are
831 1.18.4.1 skrll * used in management frames to indicate the result of an operation.
832 1.1 dyoung *
833 1.1 dyoung * Unlisted codes are reserved
834 1.1 dyoung */
835 1.1 dyoung
836 1.1 dyoung enum {
837 1.1 dyoung IEEE80211_REASON_UNSPECIFIED = 1,
838 1.1 dyoung IEEE80211_REASON_AUTH_EXPIRE = 2,
839 1.1 dyoung IEEE80211_REASON_AUTH_LEAVE = 3,
840 1.1 dyoung IEEE80211_REASON_ASSOC_EXPIRE = 4,
841 1.1 dyoung IEEE80211_REASON_ASSOC_TOOMANY = 5,
842 1.1 dyoung IEEE80211_REASON_NOT_AUTHED = 6,
843 1.1 dyoung IEEE80211_REASON_NOT_ASSOCED = 7,
844 1.1 dyoung IEEE80211_REASON_ASSOC_LEAVE = 8,
845 1.1 dyoung IEEE80211_REASON_ASSOC_NOT_AUTHED = 9,
846 1.18.4.1 skrll IEEE80211_REASON_DISASSOC_PWRCAP_BAD = 10, /* 11h */
847 1.18.4.1 skrll IEEE80211_REASON_DISASSOC_SUPCHAN_BAD = 11, /* 11h */
848 1.18.4.1 skrll IEEE80211_REASON_IE_INVALID = 13, /* 11i */
849 1.18.4.1 skrll IEEE80211_REASON_MIC_FAILURE = 14, /* 11i */
850 1.18.4.1 skrll IEEE80211_REASON_4WAY_HANDSHAKE_TIMEOUT = 15, /* 11i */
851 1.18.4.1 skrll IEEE80211_REASON_GROUP_KEY_UPDATE_TIMEOUT = 16, /* 11i */
852 1.18.4.1 skrll IEEE80211_REASON_IE_IN_4WAY_DIFFERS = 17, /* 11i */
853 1.18.4.1 skrll IEEE80211_REASON_GROUP_CIPHER_INVALID = 18, /* 11i */
854 1.18.4.1 skrll IEEE80211_REASON_PAIRWISE_CIPHER_INVALID= 19, /* 11i */
855 1.18.4.1 skrll IEEE80211_REASON_AKMP_INVALID = 20, /* 11i */
856 1.18.4.1 skrll IEEE80211_REASON_UNSUPP_RSN_IE_VERSION = 21, /* 11i */
857 1.18.4.1 skrll IEEE80211_REASON_INVALID_RSN_IE_CAP = 22, /* 11i */
858 1.18.4.1 skrll IEEE80211_REASON_802_1X_AUTH_FAILED = 23, /* 11i */
859 1.18.4.1 skrll IEEE80211_REASON_CIPHER_SUITE_REJECTED = 24, /* 11i */
860 1.6 dyoung
861 1.1 dyoung IEEE80211_STATUS_SUCCESS = 0,
862 1.1 dyoung IEEE80211_STATUS_UNSPECIFIED = 1,
863 1.1 dyoung IEEE80211_STATUS_CAPINFO = 10,
864 1.1 dyoung IEEE80211_STATUS_NOT_ASSOCED = 11,
865 1.1 dyoung IEEE80211_STATUS_OTHER = 12,
866 1.1 dyoung IEEE80211_STATUS_ALG = 13,
867 1.1 dyoung IEEE80211_STATUS_SEQUENCE = 14,
868 1.1 dyoung IEEE80211_STATUS_CHALLENGE = 15,
869 1.1 dyoung IEEE80211_STATUS_TIMEOUT = 16,
870 1.1 dyoung IEEE80211_STATUS_TOOMANY = 17,
871 1.1 dyoung IEEE80211_STATUS_BASIC_RATE = 18,
872 1.18.4.1 skrll IEEE80211_STATUS_SP_REQUIRED = 19, /* 11b */
873 1.18.4.1 skrll IEEE80211_STATUS_PBCC_REQUIRED = 20, /* 11b */
874 1.18.4.1 skrll IEEE80211_STATUS_CA_REQUIRED = 21, /* 11b */
875 1.18.4.1 skrll IEEE80211_STATUS_SPECMGMT_REQUIRED = 22, /* 11h */
876 1.18.4.1 skrll IEEE80211_STATUS_PWRCAP_REQUIRED = 23, /* 11h */
877 1.18.4.1 skrll IEEE80211_STATUS_SUPCHAN_REQUIRED = 24, /* 11h */
878 1.18.4.1 skrll IEEE80211_STATUS_SHORTSLOT_REQUIRED = 25, /* 11g */
879 1.18.4.1 skrll IEEE80211_STATUS_DSSSOFDM_REQUIRED = 26, /* 11g */
880 1.18.4.1 skrll IEEE80211_STATUS_INVALID_IE = 40, /* 11i */
881 1.18.4.1 skrll IEEE80211_STATUS_GROUP_CIPHER_INVALID = 41, /* 11i */
882 1.18.4.1 skrll IEEE80211_STATUS_PAIRWISE_CIPHER_INVALID = 42, /* 11i */
883 1.18.4.1 skrll IEEE80211_STATUS_AKMP_INVALID = 43, /* 11i */
884 1.18.4.1 skrll IEEE80211_STATUS_UNSUPP_RSN_IE_VERSION = 44, /* 11i */
885 1.18.4.1 skrll IEEE80211_STATUS_INVALID_RSN_IE_CAP = 45, /* 11i */
886 1.18.4.1 skrll IEEE80211_STATUS_CIPHER_SUITE_REJECTED = 46, /* 11i */
887 1.1 dyoung };
888 1.1 dyoung
889 1.7 mycroft #define IEEE80211_WEP_KEYLEN 5 /* 40bit */
890 1.7 mycroft #define IEEE80211_WEP_IVLEN 3 /* 24bit */
891 1.7 mycroft #define IEEE80211_WEP_KIDLEN 1 /* 1 octet */
892 1.7 mycroft #define IEEE80211_WEP_CRCLEN 4 /* CRC-32 */
893 1.8 dyoung #define IEEE80211_WEP_TOTLEN (IEEE80211_WEP_IVLEN + \
894 1.8 dyoung IEEE80211_WEP_KIDLEN + \
895 1.8 dyoung IEEE80211_WEP_CRCLEN)
896 1.13 dyoung #define IEEE80211_WEP_NKID 4 /* number of key ids */
897 1.13 dyoung
898 1.7 mycroft /*
899 1.7 mycroft * 802.11i defines an extended IV for use with non-WEP ciphers.
900 1.7 mycroft * When the EXTIV bit is set in the key id byte an additional
901 1.7 mycroft * 4 bytes immediately follow the IV for TKIP. For CCMP the
902 1.7 mycroft * EXTIV bit is likewise set but the 8 bytes represent the
903 1.7 mycroft * CCMP header rather than IV+extended-IV.
904 1.7 mycroft */
905 1.7 mycroft #define IEEE80211_WEP_EXTIV 0x20
906 1.7 mycroft #define IEEE80211_WEP_EXTIVLEN 4 /* extended IV length */
907 1.7 mycroft #define IEEE80211_WEP_MICLEN 8 /* trailing MIC */
908 1.1 dyoung
909 1.7 mycroft #define IEEE80211_CRC_LEN 4
910 1.1 dyoung
911 1.6 dyoung /*
912 1.6 dyoung * Maximum acceptable MTU is:
913 1.6 dyoung * IEEE80211_MAX_LEN - WEP overhead - CRC -
914 1.6 dyoung * QoS overhead - RSN/WPA overhead
915 1.6 dyoung * Min is arbitrarily chosen > IEEE80211_MIN_LEN. The default
916 1.6 dyoung * mtu is Ethernet-compatible; it's set by ether_ifattach.
917 1.6 dyoung */
918 1.7 mycroft #define IEEE80211_MTU_MAX 2290
919 1.7 mycroft #define IEEE80211_MTU_MIN 32
920 1.6 dyoung
921 1.7 mycroft #define IEEE80211_MAX_LEN (2300 + IEEE80211_CRC_LEN + \
922 1.1 dyoung (IEEE80211_WEP_IVLEN + IEEE80211_WEP_KIDLEN + IEEE80211_WEP_CRCLEN))
923 1.7 mycroft #define IEEE80211_ACK_LEN \
924 1.7 mycroft (sizeof(struct ieee80211_frame_ack) + IEEE80211_CRC_LEN)
925 1.5 dyoung #define IEEE80211_MIN_LEN \
926 1.5 dyoung (sizeof(struct ieee80211_frame_min) + IEEE80211_CRC_LEN)
927 1.3 dyoung
928 1.7 mycroft /*
929 1.7 mycroft * The 802.11 spec says at most 2007 stations may be
930 1.7 mycroft * associated at once. For most AP's this is way more
931 1.7 mycroft * than is feasible so we use a default of 128. This
932 1.7 mycroft * number may be overridden by the driver and/or by
933 1.7 mycroft * user configuration.
934 1.7 mycroft */
935 1.7 mycroft #define IEEE80211_AID_MAX 2007
936 1.7 mycroft #define IEEE80211_AID_DEF 128
937 1.3 dyoung
938 1.7 mycroft #define IEEE80211_AID(b) ((b) &~ 0xc000)
939 1.1 dyoung
940 1.13 dyoung /*
941 1.1 dyoung * RTS frame length parameters. The default is specified in
942 1.15 skrll * the 802.11 spec as 512; we treat it as implementation-dependent
943 1.15 skrll * so it's defined in ieee80211_var.h. The max may be wrong
944 1.15 skrll * for jumbo frames.
945 1.1 dyoung */
946 1.7 mycroft #define IEEE80211_RTS_MIN 1
947 1.15 skrll #define IEEE80211_RTS_MAX 2346
948 1.15 skrll
949 1.15 skrll /*
950 1.15 skrll * TX fragmentation parameters. As above for RTS, we treat
951 1.15 skrll * default as implementation-dependent so define it elsewhere.
952 1.15 skrll */
953 1.15 skrll #define IEEE80211_FRAG_MIN 256
954 1.15 skrll #define IEEE80211_FRAG_MAX 2346
955 1.1 dyoung
956 1.8 dyoung /*
957 1.18.4.1 skrll * Beacon interval (TU's). Min+max come from WiFi requirements.
958 1.18.4.1 skrll * As above, we treat default as implementation-dependent so
959 1.18.4.1 skrll * define it elsewhere.
960 1.18.4.1 skrll */
961 1.18.4.1 skrll #define IEEE80211_BINTVAL_MAX 1000 /* max beacon interval (TU's) */
962 1.18.4.1 skrll #define IEEE80211_BINTVAL_MIN 25 /* min beacon interval (TU's) */
963 1.18.4.1 skrll
964 1.18.4.1 skrll /*
965 1.18.4.1 skrll * DTIM period (beacons). Min+max are not really defined
966 1.18.4.1 skrll * by the protocol but we want them publicly visible so
967 1.18.4.1 skrll * define them here.
968 1.18.4.1 skrll */
969 1.18.4.1 skrll #define IEEE80211_DTIM_MAX 15 /* max DTIM period */
970 1.18.4.1 skrll #define IEEE80211_DTIM_MIN 1 /* min DTIM period */
971 1.18.4.1 skrll
972 1.18.4.1 skrll /*
973 1.18.4.1 skrll * Beacon miss threshold (beacons). As for DTIM, we define
974 1.18.4.1 skrll * them here to be publicly visible. Note the max may be
975 1.18.4.1 skrll * clamped depending on device capabilities.
976 1.18.4.1 skrll */
977 1.18.4.1 skrll #define IEEE80211_HWBMISS_MIN 1
978 1.18.4.1 skrll #define IEEE80211_HWBMISS_MAX 255
979 1.18.4.1 skrll
980 1.18.4.1 skrll /*
981 1.8 dyoung * 802.11 frame duration definitions.
982 1.8 dyoung */
983 1.8 dyoung
984 1.8 dyoung struct ieee80211_duration {
985 1.8 dyoung uint16_t d_rts_dur;
986 1.8 dyoung uint16_t d_data_dur;
987 1.8 dyoung uint16_t d_plcp_len;
988 1.10 mycroft uint8_t d_residue; /* unused octets in time slot */
989 1.8 dyoung };
990 1.8 dyoung
991 1.8 dyoung /* One Time Unit (TU) is 1Kus = 1024 microseconds. */
992 1.8 dyoung #define IEEE80211_DUR_TU 1024
993 1.8 dyoung
994 1.8 dyoung /* IEEE 802.11b durations for DSSS PHY in microseconds */
995 1.8 dyoung #define IEEE80211_DUR_DS_LONG_PREAMBLE 144
996 1.8 dyoung #define IEEE80211_DUR_DS_SHORT_PREAMBLE 72
997 1.11 mycroft
998 1.11 mycroft #define IEEE80211_DUR_DS_SLOW_PLCPHDR 48
999 1.8 dyoung #define IEEE80211_DUR_DS_FAST_PLCPHDR 24
1000 1.8 dyoung #define IEEE80211_DUR_DS_SLOW_ACK 112
1001 1.8 dyoung #define IEEE80211_DUR_DS_FAST_ACK 56
1002 1.8 dyoung #define IEEE80211_DUR_DS_SLOW_CTS 112
1003 1.8 dyoung #define IEEE80211_DUR_DS_FAST_CTS 56
1004 1.11 mycroft
1005 1.8 dyoung #define IEEE80211_DUR_DS_SLOT 20
1006 1.8 dyoung #define IEEE80211_DUR_DS_SIFS 10
1007 1.8 dyoung #define IEEE80211_DUR_DS_PIFS (IEEE80211_DUR_DS_SIFS + IEEE80211_DUR_DS_SLOT)
1008 1.8 dyoung #define IEEE80211_DUR_DS_DIFS (IEEE80211_DUR_DS_SIFS + \
1009 1.8 dyoung 2 * IEEE80211_DUR_DS_SLOT)
1010 1.8 dyoung #define IEEE80211_DUR_DS_EIFS (IEEE80211_DUR_DS_SIFS + \
1011 1.8 dyoung IEEE80211_DUR_DS_SLOW_ACK + \
1012 1.8 dyoung IEEE80211_DUR_DS_LONG_PREAMBLE + \
1013 1.8 dyoung IEEE80211_DUR_DS_SLOW_PLCPHDR + \
1014 1.8 dyoung IEEE80211_DUR_DIFS)
1015 1.8 dyoung
1016 1.18.4.1 skrll /*
1017 1.18.4.1 skrll * Atheros fast-frame encapsulation format.
1018 1.18.4.1 skrll * FF max payload:
1019 1.18.4.1 skrll * 802.2 + FFHDR + HPAD + 802.3 + 802.2 + 1500 + SPAD + 802.3 + 802.2 + 1500:
1020 1.18.4.1 skrll * 8 + 4 + 4 + 14 + 8 + 1500 + 6 + 14 + 8 + 1500
1021 1.18.4.1 skrll * = 3066
1022 1.18.4.1 skrll */
1023 1.18.4.1 skrll /* fast frame header is 32-bits */
1024 1.18.4.1 skrll #define ATH_FF_PROTO 0x0000003f /* protocol */
1025 1.18.4.1 skrll #define ATH_FF_PROTO_S 0
1026 1.18.4.1 skrll #define ATH_FF_FTYPE 0x000000c0 /* frame type */
1027 1.18.4.1 skrll #define ATH_FF_FTYPE_S 6
1028 1.18.4.1 skrll #define ATH_FF_HLEN32 0x00000300 /* optional hdr length */
1029 1.18.4.1 skrll #define ATH_FF_HLEN32_S 8
1030 1.18.4.1 skrll #define ATH_FF_SEQNUM 0x001ffc00 /* sequence number */
1031 1.18.4.1 skrll #define ATH_FF_SEQNUM_S 10
1032 1.18.4.1 skrll #define ATH_FF_OFFSET 0xffe00000 /* offset to 2nd payload */
1033 1.18.4.1 skrll #define ATH_FF_OFFSET_S 21
1034 1.18.4.1 skrll
1035 1.18.4.1 skrll #define ATH_FF_MAX_HDR_PAD 4
1036 1.18.4.1 skrll #define ATH_FF_MAX_SEP_PAD 6
1037 1.18.4.1 skrll #define ATH_FF_MAX_HDR 30
1038 1.18.4.1 skrll
1039 1.18.4.1 skrll #define ATH_FF_PROTO_L2TUNNEL 0 /* L2 tunnel protocol */
1040 1.18.4.1 skrll #define ATH_FF_ETH_TYPE 0x88bd /* Ether type for encapsulated frames */
1041 1.18.4.1 skrll #define ATH_FF_SNAP_ORGCODE_0 0x00
1042 1.18.4.1 skrll #define ATH_FF_SNAP_ORGCODE_1 0x03
1043 1.18.4.1 skrll #define ATH_FF_SNAP_ORGCODE_2 0x7f
1044 1.1 dyoung
1045 1.16 elad #endif /* !_NET80211_IEEE80211_H_ */
1046