ieee80211.h revision 1.4 1 1.4 dyoung /* $NetBSD: ieee80211.h,v 1.4 2003/10/15 11:43:51 dyoung Exp $ */
2 1.1 dyoung /*-
3 1.1 dyoung * Copyright (c) 2001 Atsushi Onoe
4 1.1 dyoung * Copyright (c) 2002, 2003 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 * 3. The name of the author may not be used to endorse or promote products
16 1.1 dyoung * derived from this software without specific prior written permission.
17 1.1 dyoung *
18 1.1 dyoung * Alternatively, this software may be distributed under the terms of the
19 1.1 dyoung * GNU General Public License ("GPL") version 2 as published by the Free
20 1.1 dyoung * Software Foundation.
21 1.1 dyoung *
22 1.1 dyoung * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
23 1.1 dyoung * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
24 1.1 dyoung * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
25 1.1 dyoung * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
26 1.1 dyoung * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
27 1.1 dyoung * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28 1.1 dyoung * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29 1.1 dyoung * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30 1.1 dyoung * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
31 1.1 dyoung * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 1.1 dyoung *
33 1.1 dyoung * $FreeBSD: src/sys/net80211/ieee80211.h,v 1.2 2003/06/27 05:13:52 sam Exp $
34 1.1 dyoung */
35 1.1 dyoung #ifndef _NET80211_IEEE80211_H_
36 1.1 dyoung #define _NET80211_IEEE80211_H_
37 1.1 dyoung
38 1.1 dyoung /*
39 1.1 dyoung * 802.11 protocol definitions.
40 1.1 dyoung */
41 1.1 dyoung
42 1.1 dyoung #define IEEE80211_ADDR_LEN 6 /* size of 802.11 address */
43 1.1 dyoung /* is 802.11 address multicast/broadcast? */
44 1.1 dyoung #define IEEE80211_IS_MULTICAST(_a) (*(_a) & 0x01)
45 1.1 dyoung
46 1.1 dyoung /* IEEE 802.11 PLCP header */
47 1.1 dyoung struct ieee80211_plcp_hdr {
48 1.1 dyoung u_int16_t i_sfd;
49 1.1 dyoung u_int8_t i_signal;
50 1.1 dyoung u_int8_t i_service;
51 1.1 dyoung u_int16_t i_length;
52 1.1 dyoung u_int16_t i_crc;
53 1.1 dyoung } __attribute__((__packed__));
54 1.1 dyoung
55 1.3 dyoung #define IEEE80211_PLCP_SFD 0xF3A0
56 1.3 dyoung #define IEEE80211_PLCP_SERVICE 0x00
57 1.3 dyoung
58 1.1 dyoung /*
59 1.1 dyoung * generic definitions for IEEE 802.11 frames
60 1.1 dyoung */
61 1.1 dyoung struct ieee80211_frame {
62 1.1 dyoung u_int8_t i_fc[2];
63 1.1 dyoung u_int8_t i_dur[2];
64 1.1 dyoung u_int8_t i_addr1[IEEE80211_ADDR_LEN];
65 1.1 dyoung u_int8_t i_addr2[IEEE80211_ADDR_LEN];
66 1.1 dyoung u_int8_t i_addr3[IEEE80211_ADDR_LEN];
67 1.1 dyoung u_int8_t i_seq[2];
68 1.1 dyoung /* possibly followed by addr4[IEEE80211_ADDR_LEN]; */
69 1.1 dyoung /* see below */
70 1.1 dyoung } __attribute__((__packed__));
71 1.1 dyoung
72 1.1 dyoung struct ieee80211_frame_addr4 {
73 1.1 dyoung u_int8_t i_fc[2];
74 1.1 dyoung u_int8_t i_dur[2];
75 1.1 dyoung u_int8_t i_addr1[IEEE80211_ADDR_LEN];
76 1.1 dyoung u_int8_t i_addr2[IEEE80211_ADDR_LEN];
77 1.1 dyoung u_int8_t i_addr3[IEEE80211_ADDR_LEN];
78 1.1 dyoung u_int8_t i_seq[2];
79 1.1 dyoung u_int8_t i_addr4[IEEE80211_ADDR_LEN];
80 1.1 dyoung } __attribute__((__packed__));
81 1.1 dyoung
82 1.1 dyoung #define IEEE80211_FC0_VERSION_MASK 0x03
83 1.1 dyoung #define IEEE80211_FC0_VERSION_SHIFT 0
84 1.1 dyoung #define IEEE80211_FC0_VERSION_0 0x00
85 1.1 dyoung #define IEEE80211_FC0_TYPE_MASK 0x0c
86 1.1 dyoung #define IEEE80211_FC0_TYPE_SHIFT 2
87 1.1 dyoung #define IEEE80211_FC0_TYPE_MGT 0x00
88 1.1 dyoung #define IEEE80211_FC0_TYPE_CTL 0x04
89 1.1 dyoung #define IEEE80211_FC0_TYPE_DATA 0x08
90 1.1 dyoung
91 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_MASK 0xf0
92 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_SHIFT 4
93 1.1 dyoung /* for TYPE_MGT */
94 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_ASSOC_REQ 0x00
95 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_ASSOC_RESP 0x10
96 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_REASSOC_REQ 0x20
97 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_REASSOC_RESP 0x30
98 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_PROBE_REQ 0x40
99 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_PROBE_RESP 0x50
100 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_BEACON 0x80
101 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_ATIM 0x90
102 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_DISASSOC 0xa0
103 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_AUTH 0xb0
104 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_DEAUTH 0xc0
105 1.1 dyoung /* for TYPE_CTL */
106 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_PS_POLL 0xa0
107 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_RTS 0xb0
108 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_CTS 0xc0
109 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_ACK 0xd0
110 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_CF_END 0xe0
111 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_CF_END_ACK 0xf0
112 1.1 dyoung /* for TYPE_DATA (bit combination) */
113 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_DATA 0x00
114 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_CF_ACK 0x10
115 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_CF_POLL 0x20
116 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_CF_ACPL 0x30
117 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_NODATA 0x40
118 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_CFACK 0x50
119 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_CFPOLL 0x60
120 1.1 dyoung #define IEEE80211_FC0_SUBTYPE_CF_ACK_CF_ACK 0x70
121 1.1 dyoung
122 1.1 dyoung #define IEEE80211_FC1_DIR_MASK 0x03
123 1.1 dyoung #define IEEE80211_FC1_DIR_NODS 0x00 /* STA->STA */
124 1.1 dyoung #define IEEE80211_FC1_DIR_TODS 0x01 /* STA->AP */
125 1.1 dyoung #define IEEE80211_FC1_DIR_FROMDS 0x02 /* AP ->STA */
126 1.1 dyoung #define IEEE80211_FC1_DIR_DSTODS 0x03 /* AP ->AP */
127 1.1 dyoung
128 1.1 dyoung #define IEEE80211_FC1_MORE_FRAG 0x04
129 1.1 dyoung #define IEEE80211_FC1_RETRY 0x08
130 1.1 dyoung #define IEEE80211_FC1_PWR_MGT 0x10
131 1.1 dyoung #define IEEE80211_FC1_MORE_DATA 0x20
132 1.1 dyoung #define IEEE80211_FC1_WEP 0x40
133 1.1 dyoung #define IEEE80211_FC1_ORDER 0x80
134 1.1 dyoung
135 1.1 dyoung #define IEEE80211_SEQ_FRAG_MASK 0x000f
136 1.1 dyoung #define IEEE80211_SEQ_FRAG_SHIFT 0
137 1.1 dyoung #define IEEE80211_SEQ_SEQ_MASK 0xfff0
138 1.1 dyoung #define IEEE80211_SEQ_SEQ_SHIFT 4
139 1.1 dyoung
140 1.1 dyoung #define IEEE80211_NWID_LEN 32
141 1.1 dyoung
142 1.1 dyoung /*
143 1.1 dyoung * BEACON management packets
144 1.1 dyoung *
145 1.1 dyoung * octet timestamp[8]
146 1.1 dyoung * octet beacon interval[2]
147 1.1 dyoung * octet capability information[2]
148 1.1 dyoung * information element
149 1.1 dyoung * octet elemid
150 1.1 dyoung * octet length
151 1.1 dyoung * octet information[length]
152 1.1 dyoung */
153 1.1 dyoung
154 1.1 dyoung typedef uint8_t *ieee80211_mgt_beacon_t;
155 1.1 dyoung
156 1.1 dyoung #define IEEE80211_BEACON_INTERVAL(beacon) \
157 1.1 dyoung ((beacon)[8] | ((beacon)[9] << 8))
158 1.1 dyoung #define IEEE80211_BEACON_CAPABILITY(beacon) \
159 1.1 dyoung ((beacon)[10] | ((beacon)[11] << 8))
160 1.1 dyoung
161 1.1 dyoung #define IEEE80211_CAPINFO_ESS 0x0001
162 1.1 dyoung #define IEEE80211_CAPINFO_IBSS 0x0002
163 1.1 dyoung #define IEEE80211_CAPINFO_CF_POLLABLE 0x0004
164 1.1 dyoung #define IEEE80211_CAPINFO_CF_POLLREQ 0x0008
165 1.1 dyoung #define IEEE80211_CAPINFO_PRIVACY 0x0010
166 1.1 dyoung #define IEEE80211_CAPINFO_SHORT_PREAMBLE 0x0020
167 1.1 dyoung #define IEEE80211_CAPINFO_PBCC 0x0040
168 1.1 dyoung #define IEEE80211_CAPINFO_CHNL_AGILITY 0x0080
169 1.1 dyoung /* bits 8-9 are reserved */
170 1.1 dyoung #define IEEE80211_CAPINFO_SHORT_SLOTTIME 0x0400
171 1.1 dyoung /* bits 11-12 are reserved */
172 1.1 dyoung #define IEEE80211_CAPINFO_DSSSOFDM 0x2000
173 1.1 dyoung /* bits 14-15 are reserved */
174 1.1 dyoung
175 1.1 dyoung /*
176 1.1 dyoung * Management information elements
177 1.1 dyoung */
178 1.1 dyoung struct ieee80211_information {
179 1.1 dyoung char ssid[IEEE80211_NWID_LEN+1];
180 1.1 dyoung struct rates {
181 1.1 dyoung u_int8_t *p;
182 1.1 dyoung } rates;
183 1.1 dyoung struct fh {
184 1.1 dyoung u_int16_t dwell;
185 1.1 dyoung u_int8_t set;
186 1.1 dyoung u_int8_t pattern;
187 1.1 dyoung u_int8_t index;
188 1.1 dyoung } fh;
189 1.1 dyoung struct ds {
190 1.1 dyoung u_int8_t channel;
191 1.1 dyoung } ds;
192 1.1 dyoung struct cf {
193 1.1 dyoung u_int8_t count;
194 1.1 dyoung u_int8_t period;
195 1.1 dyoung u_int8_t maxdur[2];
196 1.1 dyoung u_int8_t dur[2];
197 1.1 dyoung } cf;
198 1.1 dyoung struct tim {
199 1.1 dyoung u_int8_t count;
200 1.1 dyoung u_int8_t period;
201 1.1 dyoung u_int8_t bitctl;
202 1.1 dyoung /* u_int8_t pvt[251]; The driver needs to use this. */
203 1.1 dyoung } tim;
204 1.1 dyoung struct ibss {
205 1.1 dyoung u_int16_t atim;
206 1.1 dyoung } ibss;
207 1.1 dyoung struct challenge {
208 1.1 dyoung u_int8_t *p;
209 1.1 dyoung u_int8_t len;
210 1.1 dyoung } challenge;
211 1.1 dyoung struct erp {
212 1.1 dyoung u_int8_t flags;
213 1.1 dyoung } erp;
214 1.1 dyoung };
215 1.1 dyoung
216 1.1 dyoung enum {
217 1.1 dyoung IEEE80211_ELEMID_SSID = 0,
218 1.1 dyoung IEEE80211_ELEMID_RATES = 1,
219 1.1 dyoung IEEE80211_ELEMID_FHPARMS = 2,
220 1.1 dyoung IEEE80211_ELEMID_DSPARMS = 3,
221 1.1 dyoung IEEE80211_ELEMID_CFPARMS = 4,
222 1.1 dyoung IEEE80211_ELEMID_TIM = 5,
223 1.1 dyoung IEEE80211_ELEMID_IBSSPARMS = 6,
224 1.1 dyoung IEEE80211_ELEMID_COUNTRY = 7,
225 1.1 dyoung IEEE80211_ELEMID_CHALLENGE = 16,
226 1.1 dyoung IEEE80211_ELEMID_ERP = 42,
227 1.1 dyoung IEEE80211_ELEMID_XRATES = 50,
228 1.1 dyoung };
229 1.4 dyoung
230 1.4 dyoung #define IEEE80211_CHALLENGE_LEN 128
231 1.1 dyoung
232 1.1 dyoung #define IEEE80211_RATE_BASIC 0x80
233 1.1 dyoung #define IEEE80211_RATE_VAL 0x7f
234 1.1 dyoung
235 1.1 dyoung /* EPR information element flags */
236 1.1 dyoung #define IEEE80211_ERP_NON_ERP_PRESENT 0x01
237 1.1 dyoung #define IEEE80211_ERP_USE_PROTECTION 0x02
238 1.1 dyoung #define IEEE80211_ERP_BARKER_MODE 0x04
239 1.1 dyoung
240 1.1 dyoung /*
241 1.1 dyoung * AUTH management packets
242 1.1 dyoung *
243 1.1 dyoung * octet algo[2]
244 1.1 dyoung * octet seq[2]
245 1.1 dyoung * octet status[2]
246 1.1 dyoung * octet chal.id
247 1.1 dyoung * octet chal.length
248 1.1 dyoung * octet chal.text[253]
249 1.1 dyoung */
250 1.1 dyoung
251 1.1 dyoung typedef u_int8_t *ieee80211_mgt_auth_t;
252 1.1 dyoung
253 1.1 dyoung #define IEEE80211_AUTH_ALGORITHM(auth) \
254 1.1 dyoung ((auth)[0] | ((auth)[1] << 8))
255 1.1 dyoung #define IEEE80211_AUTH_TRANSACTION(auth) \
256 1.1 dyoung ((auth)[2] | ((auth)[3] << 8))
257 1.1 dyoung #define IEEE80211_AUTH_STATUS(auth) \
258 1.1 dyoung ((auth)[4] | ((auth)[5] << 8))
259 1.1 dyoung
260 1.1 dyoung #define IEEE80211_AUTH_ALG_OPEN 0x0000
261 1.1 dyoung #define IEEE80211_AUTH_ALG_SHARED 0x0001
262 1.1 dyoung
263 1.1 dyoung enum {
264 1.1 dyoung IEEE80211_AUTH_OPEN_REQUEST = 1,
265 1.1 dyoung IEEE80211_AUTH_OPEN_RESPONSE = 2,
266 1.1 dyoung };
267 1.1 dyoung
268 1.1 dyoung enum {
269 1.1 dyoung IEEE80211_AUTH_SHARED_REQUEST = 1,
270 1.1 dyoung IEEE80211_AUTH_SHARED_CHALLENGE = 2,
271 1.1 dyoung IEEE80211_AUTH_SHARED_RESPONSE = 3,
272 1.1 dyoung IEEE80211_AUTH_SHARED_PASS = 4,
273 1.1 dyoung };
274 1.1 dyoung
275 1.1 dyoung /*
276 1.1 dyoung * Reason codes
277 1.1 dyoung *
278 1.1 dyoung * Unlisted codes are reserved
279 1.1 dyoung */
280 1.1 dyoung
281 1.1 dyoung enum {
282 1.1 dyoung IEEE80211_REASON_UNSPECIFIED = 1,
283 1.1 dyoung IEEE80211_REASON_AUTH_EXPIRE = 2,
284 1.1 dyoung IEEE80211_REASON_AUTH_LEAVE = 3,
285 1.1 dyoung IEEE80211_REASON_ASSOC_EXPIRE = 4,
286 1.1 dyoung IEEE80211_REASON_ASSOC_TOOMANY = 5,
287 1.1 dyoung IEEE80211_REASON_NOT_AUTHED = 6,
288 1.1 dyoung IEEE80211_REASON_NOT_ASSOCED = 7,
289 1.1 dyoung IEEE80211_REASON_ASSOC_LEAVE = 8,
290 1.1 dyoung IEEE80211_REASON_ASSOC_NOT_AUTHED = 9,
291 1.1 dyoung
292 1.1 dyoung IEEE80211_STATUS_SUCCESS = 0,
293 1.1 dyoung IEEE80211_STATUS_UNSPECIFIED = 1,
294 1.1 dyoung IEEE80211_STATUS_CAPINFO = 10,
295 1.1 dyoung IEEE80211_STATUS_NOT_ASSOCED = 11,
296 1.1 dyoung IEEE80211_STATUS_OTHER = 12,
297 1.1 dyoung IEEE80211_STATUS_ALG = 13,
298 1.1 dyoung IEEE80211_STATUS_SEQUENCE = 14,
299 1.1 dyoung IEEE80211_STATUS_CHALLENGE = 15,
300 1.1 dyoung IEEE80211_STATUS_TIMEOUT = 16,
301 1.1 dyoung IEEE80211_STATUS_TOOMANY = 17,
302 1.1 dyoung IEEE80211_STATUS_BASIC_RATE = 18,
303 1.1 dyoung IEEE80211_STATUS_SP_REQUIRED = 19,
304 1.1 dyoung IEEE80211_STATUS_PBCC_REQUIRED = 20,
305 1.1 dyoung IEEE80211_STATUS_CA_REQUIRED = 21,
306 1.1 dyoung IEEE80211_STATUS_TOO_MANY_STATIONS = 22,
307 1.1 dyoung IEEE80211_STATUS_RATES = 23,
308 1.1 dyoung IEEE80211_STATUS_SHORTSLOT_REQUIRED = 25,
309 1.1 dyoung IEEE80211_STATUS_DSSSOFDM_REQUIRED = 26,
310 1.1 dyoung };
311 1.1 dyoung
312 1.1 dyoung #define IEEE80211_WEP_KEYLEN 5 /* 40bit */
313 1.1 dyoung #define IEEE80211_WEP_IVLEN 3 /* 24bit */
314 1.1 dyoung #define IEEE80211_WEP_KIDLEN 1 /* 1 octet */
315 1.1 dyoung #define IEEE80211_WEP_CRCLEN 4 /* CRC-32 */
316 1.1 dyoung #define IEEE80211_WEP_NKID 4 /* number of key ids */
317 1.1 dyoung
318 1.1 dyoung #define IEEE80211_CRC_LEN 4
319 1.1 dyoung
320 1.1 dyoung #define IEEE80211_MTU 1500
321 1.1 dyoung #define IEEE80211_MAX_LEN (2300 + IEEE80211_CRC_LEN + \
322 1.1 dyoung (IEEE80211_WEP_IVLEN + IEEE80211_WEP_KIDLEN + IEEE80211_WEP_CRCLEN))
323 1.3 dyoung
324 1.3 dyoung #define IEEE80211_MAX_AID 2007
325 1.3 dyoung
326 1.3 dyoung #define IEEE80211_AID_SET(b, w) \
327 1.3 dyoung ((w)[((b) & ~0xc000) / 32] |= (1 << (((b) & ~0xc000) % 32)))
328 1.3 dyoung #define IEEE80211_AID_CLR(b, w) \
329 1.3 dyoung ((w)[((b) & ~0xc000) / 32] &= ~(1 << (((b) & ~0xc000) % 32)))
330 1.3 dyoung #define IEEE80211_AID_ISSET(b, w) \
331 1.3 dyoung ((w)[((b) & ~0xc000) / 32] & (1 << (((b) & ~0xc000) % 32)))
332 1.1 dyoung
333 1.1 dyoung /*
334 1.1 dyoung * RTS frame length parameters. The default is specified in
335 1.1 dyoung * the 802.11 spec. The max may be wrong for jumbo frames.
336 1.1 dyoung */
337 1.1 dyoung #define IEEE80211_RTS_DEFAULT 512
338 1.1 dyoung #define IEEE80211_RTS_MIN 1
339 1.1 dyoung #define IEEE80211_RTS_MAX IEEE80211_MAX_LEN
340 1.1 dyoung
341 1.1 dyoung enum {
342 1.1 dyoung IEEE80211_AUTH_NONE = 0,
343 1.1 dyoung IEEE80211_AUTH_OPEN = 1,
344 1.1 dyoung IEEE80211_AUTH_SHARED = 2,
345 1.1 dyoung };
346 1.1 dyoung
347 1.1 dyoung #endif /* _NET80211_IEEE80211_H_ */
348