87515e34ff
Thanks to dyoung@, scw@, and perry@ for help testing. 2005-08-30 15:27 avatar Properly set ic_curchan before calling back to device driver to do channel switching(ifconfig devX channel Y). This fix should make channel changing works again in monitor mode. Submitted by: sam X-MFC-With: other ic_curchan changes 2005-08-13 18:50 sam revert 1.64: we cannot use the channel characteristics to decide when to do 11g erp sta accounting because b/g channels show up as false positives when operating in 11b. Noticed by: Michal Mertl 2005-08-13 18:31 sam Extend acl support to pass ioctl requests through and use this to add support for getting the current policy setting and collecting the list of mac addresses in the acl table. Submitted by: Michal Mertl (original version) MFC after: 2 weeks 2005-08-10 18:42 sam Don't use ic_curmode to decide when to do 11g station accounting, use the station channel properties. Fixes assert failure/bogus operation when an ap is operating in 11a and has associated stations then switches to 11g. Noticed by: Michal Mertl Reviewed by: avatar MFC after: 2 weeks 2005-08-10 17:22 sam Clarify/fix handling of the current channel: o add ic_curchan and use it uniformly for specifying the current channel instead of overloading ic->ic_bss->ni_chan (or in some drivers ic_ibss_chan) o add ieee80211_scanparams structure to encapsulate scanning-related state captured for rx frames o move rx beacon+probe response frame handling into separate routines o change beacon+probe response handling to treat the scan table more like a scan cache--look for an existing entry before adding a new one; this combined with ic_curchan use corrects handling of stations that were previously found at a different channel o move adhoc neighbor discovery by beacon+probe response frames to a new ieee80211_add_neighbor routine Reviewed by: avatar Tested by: avatar, Michal Mertl MFC after: 2 weeks 2005-08-09 11:19 rwatson Propagate rename of IFF_OACTIVE and IFF_RUNNING to IFF_DRV_OACTIVE and IFF_DRV_RUNNING, as well as the move from ifnet.if_flags to ifnet.if_drv_flags. Device drivers are now responsible for synchronizing access to these flags, as they are in if_drv_flags. This helps prevent races between the network stack and device driver in maintaining the interface flags field. Many __FreeBSD__ and __FreeBSD_version checks maintained and continued; some less so. Reviewed by: pjd, bz MFC after: 7 days 2005-08-08 19:46 sam Split crypto tx+rx key indices and add a key index -> node mapping table: Crypto changes: o change driver/net80211 key_alloc api to return tx+rx key indices; a driver can leave the rx key index set to IEEE80211_KEYIX_NONE or set it to be the same as the tx key index (the former disables use of the key index in building the keyix->node mapping table and is the default setup for naive drivers by null_key_alloc) o add cs_max_keyid to crypto state to specify the max h/w key index a driver will return; this is used to allocate the key index mapping table and to bounds check table loookups o while here introduce ieee80211_keyix (finally) for the type of a h/w key index o change crypto notifiers for rx failures to pass the rx key index up as appropriate (michael failure, replay, etc.) Node table changes: o optionally allocate a h/w key index to node mapping table for the station table using the max key index setting supplied by drivers (note the scan table does not get a map) o defer node table allocation to lateattach so the driver has a chance to set the max key id to size the key index map o while here also defer the aid bitmap allocation o add new ieee80211_find_rxnode_withkey api to find a sta/node entry on frame receive with an optional h/w key index to use in checking mapping table; also updates the map if it does a hash lookup and the found node has a rx key index set in the unicast key; note this work is separated from the old ieee80211_find_rxnode call so drivers do not need to be aware of the new mechanism o move some node table manipulation under the node table lock to close a race on node delete o add ieee80211_node_delucastkey to do the dirty work of deleting unicast key state for a node (deletes any key and handles key map references) Ath driver: o nuke private sc_keyixmap mechansim in favor of net80211 support o update key alloc api These changes close several race conditions for the ath driver operating in ap mode. Other drivers should see no change. Station mode operation for ath no longer uses the key index map but performance tests show no noticeable change and this will be fixed when the scan table is eliminated with the new scanning support. Tested by: Michal Mertl, avatar, others Reviewed by: avatar, others MFC after: 2 weeks 2005-08-08 06:49 sam use ieee80211_iterate_nodes to retrieve station data; the previous code walked the list w/o locking MFC after: 1 week 2005-08-08 04:30 sam Cleanup beacon/listen interval handling: o separate configured beacon interval from listen interval; this avoids potential use of one value for the other (e.g. setting powersavesleep to 0 clobbers the beacon interval used in hostap or ibss mode) o bounds check the beacon interval received in probe response and beacon frames and drop frames with bogus settings; not clear if we should instead clamp the value as any alteration would result in mismatched sta+ap configuration and probably be more confusing (don't want to log to the console but perhaps ok with rate limiting) o while here up max beacon interval to reflect WiFi standard Noticed by: Martin <nakal@nurfuerspam.de> MFC after: 1 week 2005-08-06 05:57 sam fix debug msg typo MFC after: 3 days 2005-08-06 05:56 sam Fix handling of frames sent prior to a station being authorized when operating in ap mode. Previously we allocated a node from the station table, sent the frame (using the node), then released the reference that "held the frame in the table". But while the frame was in flight the node might be reclaimed which could lead to problems. The solution is to add an ieee80211_tmp_node routine that crafts a node that does exist in a table and so isn't ever reclaimed; it exists only so long as the associated frame is in flight. MFC after: 5 days 2005-07-31 07:12 sam close a race between reclaiming a node when a station is inactive and sending the null data frame used to probe inactive stations MFC after: 5 days 2005-07-27 05:41 sam when bridging internally bypass the bss node as traffic to it must follow the normal input path Submitted by: Michal Mertl MFC after: 5 days 2005-07-27 03:53 sam bandaid ni_fails handling so ap's with association failures are reconsidered after a bit; a proper fix involves more changes to the scanning infrastructure Reviewed by: avatar, David Young MFC after: 5 days 2005-07-23 01:16 sam the AREF flag is only meaningful in ap mode; adhoc neighbors now are timed out of the sta/neighbor table 2005-07-23 00:25 sam o move inactivity-related debug msgs under IEEE80211_MSG_INACT o probe inactive neighbors in adhoc mode (they don't have an association id so previously were being timed out) MFC after: 3 days 2005-07-22 22:11 sam split xmit of probe request frame out into a separate routine that takes explicit parameters; this will be needed when scanning is decoupled from the state machine to do bg scanning MFC after: 3 days 2005-07-22 21:48 sam split 802.11 frame xmit setup code into ieee80211_send_setup MFC after: 3 days 2005-07-22 18:57 sam simplify ic_newassoc callback MFC after: 3 days 2005-07-22 18:54 sam simplify ieee80211_ibss_merge api MFC after: 3 days 2005-07-22 18:50 sam add stats we know we'll need soon and some spare fields for future expansion MFC after: 3 days 2005-07-22 18:45 sam simplify tim callback api MFC after: 3 days 2005-07-22 18:42 sam don't include 802.3 header in min frame length calculation as it may not be present for a frag; fixes problem with small (fragmented) frames being dropped Obtained from: Atheros MFC after: 3 days 2005-07-22 18:36 sam simplify ieee80211_node_authorize and ieee80211_node_unauthorize api's MFC after: 3 days 2005-07-22 18:31 sam simplifiy ieee80211_send_nulldata api MFC after: 3 days 2005-07-22 18:29 sam simplify rate set api's by removing ic parameter (implicit in node reference) MFC after: 3 days 2005-07-22 18:21 sam reject association requests with a wpa/rsn ie when wpa/rsn is not configured on the ap; previously we either ignored the ie or (possibly) failed an assertion Obtained from: Atheros MFC after: 3 days 2005-07-22 18:16 sam missed one in last commit; add device name to discard msgs 2005-07-22 18:13 sam include device name in discard msgs 2005-07-22 18:12 sam add diag msgs for frames discarded because the direction field is wrong 2005-07-22 18:08 sam split data frame delivery out to a new function ieee80211_deliver_data 2005-07-22 18:00 sam o add IEEE80211_IOC_FRAGTHRESHOLD for getting+setting the tx fragmentation threshold o fix bounds checking on IEEE80211_IOC_RTSTHRESHOLD MFC after: 3 days 2005-07-22 17:55 sam o add IEEE80211_FRAG_DEFAULT o move default settings for RTS and frag thresholds to ieee80211_var.h 2005-07-22 17:50 sam diff reduction against p4: define IEEE80211_FIXED_RATE_NONE and use it instead of -1 2005-07-22 17:37 sam add flags missed in last merge 2005-07-22 17:36 sam Diff reduction against p4: o add ic_flags_ext for eventual extention of ic_flags o define/reserve flag+capabilities bits for superg, bg scan, and roaming support o refactor debug msg macros MFC after: 3 days 2005-07-22 06:17 sam send a response when an auth request is denied due to an acl; might be better to silently ignore the frame but this way we give stations a chance of figuring out what's wrong 2005-07-22 06:15 sam remove excess whitespace 2005-07-22 05:55 sam use IF_HANDOFF when bridging frames internally so if_start gets called; fixes communication between associated sta's MFC after: 3 days 2005-07-11 04:06 sam Handle encrypt of arbitarily fragmented mbuf chains: previously we bailed if we couldn't collect the 16-bytes of data required for an aes block cipher in 2 mbufs; now we deal with it. While here make space accounting signed so a sanity check does the right thing for malformed mbuf chains. Approved by: re (scottl) 2005-07-11 04:00 sam nuke assert that duplicates real check Reviewed by: avatar Approved by: re (scottl)
428 lines
18 KiB
C
428 lines
18 KiB
C
/* $NetBSD: ieee80211_var.h,v 1.21 2005/11/18 16:40:09 skrll Exp $ */
|
|
/*-
|
|
* Copyright (c) 2001 Atsushi Onoe
|
|
* Copyright (c) 2002-2005 Sam Leffler, Errno Consulting
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
* documentation and/or other materials provided with the distribution.
|
|
* 3. The name of the author may not be used to endorse or promote products
|
|
* derived from this software without specific prior written permission.
|
|
*
|
|
* Alternatively, this software may be distributed under the terms of the
|
|
* GNU General Public License ("GPL") version 2 as published by the Free
|
|
* Software Foundation.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
*
|
|
* $FreeBSD: src/sys/net80211/ieee80211_var.h,v 1.30 2005/08/10 16:22:29 sam Exp $
|
|
*/
|
|
#ifndef _NET80211_IEEE80211_VAR_H_
|
|
#define _NET80211_IEEE80211_VAR_H_
|
|
|
|
/*
|
|
* Definitions for IEEE 802.11 drivers.
|
|
*/
|
|
#define IEEE80211_DEBUG
|
|
#undef IEEE80211_DEBUG_REFCNT /* node refcnt stuff */
|
|
|
|
/* NB: portability glue must go first */
|
|
#ifdef __NetBSD__
|
|
#include <net80211/ieee80211_netbsd.h>
|
|
#elif __FreeBSD__
|
|
#include <net80211/ieee80211_freebsd.h>
|
|
#elif __linux__
|
|
#include <net80211/ieee80211_linux.h>
|
|
#else
|
|
#error "No support for your operating system!"
|
|
#endif
|
|
|
|
#include <sys/queue.h> /* XXX */
|
|
|
|
#include <net80211/_ieee80211.h>
|
|
#include <net80211/ieee80211.h>
|
|
#include <net80211/ieee80211_crypto.h>
|
|
#include <net80211/ieee80211_ioctl.h> /* for ieee80211_stats */
|
|
#include <net80211/ieee80211_node.h>
|
|
#include <net80211/ieee80211_proto.h>
|
|
|
|
#define IEEE80211_TXPOWER_MAX 100 /* .5 dbM (XXX units?) */
|
|
#define IEEE80211_TXPOWER_MIN 0 /* kill radio */
|
|
|
|
#define IEEE80211_DTIM_MAX 15 /* max DTIM period */
|
|
#define IEEE80211_DTIM_MIN 1 /* min DTIM period */
|
|
#define IEEE80211_DTIM_DEFAULT 1 /* default DTIM period */
|
|
|
|
/* NB: min+max come from WiFi requirements */
|
|
#define IEEE80211_BINTVAL_MAX 1000 /* max beacon interval (TU's) */
|
|
#define IEEE80211_BINTVAL_MIN 25 /* min beacon interval (TU's) */
|
|
#define IEEE80211_BINTVAL_DEFAULT 100 /* default beacon interval (TU's) */
|
|
|
|
#define IEEE80211_PS_SLEEP 0x1 /* STA is in power saving mode */
|
|
#define IEEE80211_PS_MAX_QUEUE 50 /* maximum saved packets */
|
|
|
|
#define IEEE80211_FIXED_RATE_NONE -1
|
|
|
|
#define IEEE80211_RTS_DEFAULT IEEE80211_RTS_MAX
|
|
#define IEEE80211_FRAG_DEFAULT IEEE80211_FRAG_MAX
|
|
|
|
#define IEEE80211_MS_TO_TU(x) (((x) * 1000) / 1024)
|
|
#define IEEE80211_TU_TO_MS(x) (((x) * 1024) / 1000)
|
|
|
|
struct ieee80211_aclator;
|
|
|
|
#define IEEE80211_PS_SLEEP 0x1 /* STA is in power saving mode */
|
|
|
|
#define IEEE80211_PS_MAX_QUEUE 50 /* maximum saved packets */
|
|
|
|
struct ieee80211com {
|
|
SLIST_ENTRY(ieee80211com) ic_next;
|
|
struct ifnet *ic_ifp; /* associated device */
|
|
struct ieee80211_stats ic_stats; /* statistics */
|
|
struct sysctllog *ic_sysctllog; /* for destroying sysctl tree */
|
|
u_int32_t ic_debug; /* debug msg flags */
|
|
int ic_vap; /* virtual AP index */
|
|
ieee80211_beacon_lock_t ic_beaconlock; /* beacon update lock */
|
|
|
|
LIST_ENTRY(ieee80211com) ic_list; /* chain of all ieee80211com */
|
|
int (*ic_reset)(struct ifnet *);
|
|
void (*ic_recv_mgmt)(struct ieee80211com *,
|
|
struct mbuf *, struct ieee80211_node *,
|
|
int, int, u_int32_t);
|
|
int (*ic_send_mgmt)(struct ieee80211com *,
|
|
struct ieee80211_node *, int, int);
|
|
int (*ic_newstate)(struct ieee80211com *,
|
|
enum ieee80211_state, int);
|
|
void (*ic_newassoc)(struct ieee80211_node *, int);
|
|
void (*ic_updateslot)(struct ifnet *);
|
|
void (*ic_set_tim)(struct ieee80211_node *, int);
|
|
u_int8_t ic_myaddr[IEEE80211_ADDR_LEN];
|
|
struct ieee80211_rateset ic_sup_rates[IEEE80211_MODE_MAX];
|
|
struct ieee80211_channel ic_channels[IEEE80211_CHAN_MAX+1];
|
|
u_int8_t ic_chan_avail[IEEE80211_CHAN_BYTES];
|
|
u_int8_t ic_chan_active[IEEE80211_CHAN_BYTES];
|
|
u_int8_t ic_chan_scan[IEEE80211_CHAN_BYTES];
|
|
struct ieee80211_node_table ic_scan; /* scan candidates */
|
|
struct ifqueue ic_mgtq;
|
|
u_int32_t ic_flags; /* state flags */
|
|
u_int32_t ic_flags_ext; /* extended state flags */
|
|
u_int32_t ic_caps; /* capabilities */
|
|
u_int16_t ic_modecaps; /* set of mode capabilities */
|
|
u_int16_t ic_curmode; /* current mode */
|
|
enum ieee80211_phytype ic_phytype; /* XXX wrong for multi-mode */
|
|
enum ieee80211_opmode ic_opmode; /* operation mode */
|
|
enum ieee80211_state ic_state; /* 802.11 state */
|
|
enum ieee80211_protmode ic_protmode; /* 802.11g protection mode */
|
|
enum ieee80211_roamingmode ic_roaming; /* roaming mode */
|
|
struct ieee80211_node_table ic_sta; /* stations/neighbors */
|
|
u_int32_t *ic_aid_bitmap; /* association id map */
|
|
u_int16_t ic_max_aid;
|
|
u_int16_t ic_sta_assoc; /* stations associated */
|
|
u_int16_t ic_ps_sta; /* stations in power save */
|
|
u_int16_t ic_ps_pending; /* ps sta's w/ pending frames */
|
|
u_int8_t *ic_tim_bitmap; /* power-save stations w/ data*/
|
|
u_int16_t ic_tim_len; /* ic_tim_bitmap size (bytes) */
|
|
u_int8_t ic_dtim_period; /* DTIM period */
|
|
u_int8_t ic_dtim_count; /* DTIM count for last bcn */
|
|
struct ifmedia ic_media; /* interface media config */
|
|
caddr_t ic_rawbpf; /* packet filter structure */
|
|
struct ieee80211_node *ic_bss; /* information for this node */
|
|
struct ieee80211_channel *ic_ibss_chan;
|
|
struct ieee80211_channel *ic_curchan; /* current channel */
|
|
int ic_fixed_rate; /* index to ic_sup_rates[] */
|
|
u_int16_t ic_rtsthreshold;
|
|
u_int16_t ic_fragthreshold;
|
|
struct ieee80211_node *(*ic_node_alloc)(struct ieee80211_node_table*);
|
|
void (*ic_node_free)(struct ieee80211_node *);
|
|
void (*ic_node_cleanup)(struct ieee80211_node *);
|
|
u_int8_t (*ic_node_getrssi)(const struct ieee80211_node*);
|
|
u_int16_t ic_lintval; /* listen interval */
|
|
u_int16_t ic_bintval; /* beacon interval */
|
|
u_int16_t ic_holdover; /* PM hold over duration */
|
|
u_int16_t ic_txmin; /* min tx retry count */
|
|
u_int16_t ic_txmax; /* max tx retry count */
|
|
u_int16_t ic_txlifetime; /* tx lifetime */
|
|
u_int16_t ic_txpowlimit; /* global tx power limit */
|
|
u_int16_t ic_bmisstimeout;/* beacon miss threshold (ms) */
|
|
u_int16_t ic_nonerpsta; /* # non-ERP stations */
|
|
u_int16_t ic_longslotsta; /* # long slot time stations */
|
|
int ic_mgt_timer; /* mgmt timeout */
|
|
int ic_inact_timer; /* inactivity timer wait */
|
|
int ic_des_esslen;
|
|
u_int8_t ic_des_essid[IEEE80211_NWID_LEN];
|
|
struct ieee80211_channel *ic_des_chan; /* desired channel */
|
|
u_int8_t ic_des_bssid[IEEE80211_ADDR_LEN];
|
|
void *ic_opt_ie; /* user-specified IE's */
|
|
u_int16_t ic_opt_ie_len; /* length of ni_opt_ie */
|
|
/*
|
|
* Inactivity timer settings for nodes.
|
|
*/
|
|
int ic_inact_init; /* initial setting */
|
|
int ic_inact_auth; /* auth but not assoc setting */
|
|
int ic_inact_run; /* authorized setting */
|
|
int ic_inact_probe; /* inactive probe time */
|
|
|
|
/*
|
|
* WME/WMM state.
|
|
*/
|
|
struct ieee80211_wme_state ic_wme;
|
|
|
|
/*
|
|
* Cipher state/configuration.
|
|
*/
|
|
struct ieee80211_crypto_state ic_crypto;
|
|
#define ic_nw_keys ic_crypto.cs_nw_keys /* XXX compatibility */
|
|
#define ic_def_txkey ic_crypto.cs_def_txkey /* XXX compatibility */
|
|
|
|
/*
|
|
* 802.1x glue. When an authenticator attaches it
|
|
* fills in this section. We assume that when ic_ec
|
|
* is setup that the methods are safe to call.
|
|
*/
|
|
const struct ieee80211_authenticator *ic_auth;
|
|
struct eapolcom *ic_ec;
|
|
|
|
/*
|
|
* Access control glue. When a control agent attaches
|
|
* it fills in this section. We assume that when ic_ac
|
|
* is setup that the methods are safe to call.
|
|
*/
|
|
const struct ieee80211_aclator *ic_acl;
|
|
void *ic_as;
|
|
};
|
|
|
|
LIST_HEAD(ieee80211com_head, ieee80211com);
|
|
|
|
extern struct ieee80211com_head ieee80211com_head;
|
|
|
|
#define IEEE80211_ADDR_EQ(a1,a2) (memcmp(a1,a2,IEEE80211_ADDR_LEN) == 0)
|
|
#define IEEE80211_ADDR_COPY(dst,src) memcpy(dst,src,IEEE80211_ADDR_LEN)
|
|
|
|
/* ic_flags */
|
|
/* NB: bits 0x4c available */
|
|
#define IEEE80211_F_FF 0x00000001 /* CONF: ATH FF enabled */
|
|
#define IEEE80211_F_TURBOP 0x00000002 /* CONF: ATH Turbo enabled*/
|
|
/* NB: this is intentionally setup to be IEEE80211_CAPINFO_PRIVACY */
|
|
#define IEEE80211_F_PRIVACY 0x00000010 /* CONF: privacy enabled */
|
|
#define IEEE80211_F_PUREG 0x00000020 /* CONF: 11g w/o 11b sta's */
|
|
#define IEEE80211_F_SCAN 0x00000080 /* STATUS: scanning */
|
|
#define IEEE80211_F_ASCAN 0x00000100 /* STATUS: active scan */
|
|
#define IEEE80211_F_SIBSS 0x00000200 /* STATUS: start IBSS */
|
|
/* NB: this is intentionally setup to be IEEE80211_CAPINFO_SHORT_SLOTTIME */
|
|
#define IEEE80211_F_SHSLOT 0x00000400 /* STATUS: use short slot time*/
|
|
#define IEEE80211_F_PMGTON 0x00000800 /* CONF: Power mgmt enable */
|
|
#define IEEE80211_F_DESBSSID 0x00001000 /* CONF: des_bssid is set */
|
|
#define IEEE80211_F_WME 0x00002000 /* CONF: enable WME use */
|
|
#define IEEE80211_F_BGSCAN 0x00004000 /* CONF: bg scan enabled (???)*/
|
|
#define IEEE80211_F_SWRETRY 0x00008000 /* CONF: sw tx retry enabled */
|
|
#define IEEE80211_F_TXPOW_FIXED 0x00010000 /* TX Power: fixed rate */
|
|
#define IEEE80211_F_IBSSON 0x00020000 /* CONF: IBSS creation enable */
|
|
#define IEEE80211_F_SHPREAMBLE 0x00040000 /* STATUS: use short preamble */
|
|
#define IEEE80211_F_DATAPAD 0x00080000 /* CONF: do alignment pad */
|
|
#define IEEE80211_F_USEPROT 0x00100000 /* STATUS: protection enabled */
|
|
#define IEEE80211_F_USEBARKER 0x00200000 /* STATUS: use barker preamble*/
|
|
#define IEEE80211_F_TIMUPDATE 0x00400000 /* STATUS: update beacon tim */
|
|
#define IEEE80211_F_WPA1 0x00800000 /* CONF: WPA enabled */
|
|
#define IEEE80211_F_WPA2 0x01000000 /* CONF: WPA2 enabled */
|
|
#define IEEE80211_F_WPA 0x01800000 /* CONF: WPA/WPA2 enabled */
|
|
#define IEEE80211_F_DROPUNENC 0x02000000 /* CONF: drop unencrypted */
|
|
#define IEEE80211_F_COUNTERM 0x04000000 /* CONF: TKIP countermeasures */
|
|
#define IEEE80211_F_HIDESSID 0x08000000 /* CONF: hide SSID in beacon */
|
|
#define IEEE80211_F_NOBRIDGE 0x10000000 /* CONF: dis. internal bridge */
|
|
#define IEEE80211_F_WMEUPDATE 0x20000000 /* STATUS: update beacon wme */
|
|
|
|
/* ic_flags_ext */
|
|
#define IEEE80211_FEXT_WDS 0x00000001 /* CONF: 4 addr allowed */
|
|
/* 0x00000006 reserved */
|
|
#define IEEE80211_FEXT_BGSCAN 0x00000008 /* STATUS: enable full bgscan completion */
|
|
|
|
/* ic_caps */
|
|
#define IEEE80211_C_WEP 0x00000001 /* CAPABILITY: WEP available */
|
|
#define IEEE80211_C_TKIP 0x00000002 /* CAPABILITY: TKIP available */
|
|
#define IEEE80211_C_AES 0x00000004 /* CAPABILITY: AES OCB avail */
|
|
#define IEEE80211_C_AES_CCM 0x00000008 /* CAPABILITY: AES CCM avail */
|
|
#define IEEE80211_C_CKIP 0x00000020 /* CAPABILITY: CKIP available */
|
|
#define IEEE80211_C_FF 0x00000040 /* CAPABILITY: ATH FF avail */
|
|
#define IEEE80211_C_TURBOP 0x00000080 /* CAPABILITY: ATH Turbo avail*/
|
|
#define IEEE80211_C_IBSS 0x00000100 /* CAPABILITY: IBSS available */
|
|
#define IEEE80211_C_PMGT 0x00000200 /* CAPABILITY: Power mgmt */
|
|
#define IEEE80211_C_HOSTAP 0x00000400 /* CAPABILITY: HOSTAP avail */
|
|
#define IEEE80211_C_AHDEMO 0x00000800 /* CAPABILITY: Old Adhoc Demo */
|
|
#define IEEE80211_C_SWRETRY 0x00001000 /* CAPABILITY: sw tx retry */
|
|
#define IEEE80211_C_TXPMGT 0x00002000 /* CAPABILITY: tx power mgmt */
|
|
#define IEEE80211_C_SHSLOT 0x00004000 /* CAPABILITY: short slottime */
|
|
#define IEEE80211_C_SHPREAMBLE 0x00008000 /* CAPABILITY: short preamble */
|
|
#define IEEE80211_C_MONITOR 0x00010000 /* CAPABILITY: monitor mode */
|
|
#define IEEE80211_C_TKIPMIC 0x00020000 /* CAPABILITY: TKIP MIC avail */
|
|
#define IEEE80211_C_WPA1 0x00800000 /* CAPABILITY: WPA1 avail */
|
|
#define IEEE80211_C_WPA2 0x01000000 /* CAPABILITY: WPA2 avail */
|
|
#define IEEE80211_C_WPA 0x01800000 /* CAPABILITY: WPA1+WPA2 avail*/
|
|
#define IEEE80211_C_BURST 0x02000000 /* CAPABILITY: frame bursting */
|
|
#define IEEE80211_C_WME 0x04000000 /* CAPABILITY: WME avail */
|
|
#define IEEE80211_C_WDS 0x08000000 /* CAPABILITY: 4-addr support */
|
|
/* 0x10000000 reserved */
|
|
#define IEEE80211_C_BGSCAN 0x20000000 /* CAPABILITY: bg scanning */
|
|
#define IEEE80211_C_TXFRAG 0x40000000 /* CAPABILITY: tx fragments */
|
|
/* XXX protection/barker? */
|
|
|
|
#define IEEE80211_C_CRYPTO 0x0000002f /* CAPABILITY: crypto alg's */
|
|
|
|
void ieee80211_ifattach(struct ieee80211com *);
|
|
void ieee80211_ifdetach(struct ieee80211com *);
|
|
void ieee80211_announce(struct ieee80211com *);
|
|
void ieee80211_media_init(struct ieee80211com *,
|
|
ifm_change_cb_t, ifm_stat_cb_t);
|
|
struct ieee80211com *ieee80211_find_vap(const u_int8_t mac[IEEE80211_ADDR_LEN]);
|
|
int ieee80211_media_change(struct ifnet *);
|
|
void ieee80211_media_status(struct ifnet *, struct ifmediareq *);
|
|
int ieee80211_ioctl(struct ieee80211com *, u_long, caddr_t);
|
|
int ieee80211_cfgget(struct ieee80211com *, u_long, caddr_t);
|
|
int ieee80211_cfgset(struct ieee80211com *, u_long, caddr_t);
|
|
void ieee80211_watchdog(struct ieee80211com *);
|
|
int ieee80211_rate2media(struct ieee80211com *, int,
|
|
enum ieee80211_phymode);
|
|
int ieee80211_media2rate(int);
|
|
u_int ieee80211_mhz2ieee(u_int, u_int);
|
|
u_int ieee80211_chan2ieee(struct ieee80211com *, struct ieee80211_channel *);
|
|
u_int ieee80211_ieee2mhz(u_int, u_int);
|
|
int ieee80211_setmode(struct ieee80211com *, enum ieee80211_phymode);
|
|
enum ieee80211_phymode ieee80211_chan2mode(struct ieee80211com *,
|
|
struct ieee80211_channel *);
|
|
int ieee80211_get_rate(struct ieee80211com *);
|
|
|
|
/*
|
|
* Key update synchronization methods. XXX should not be visible.
|
|
*/
|
|
static __inline void
|
|
ieee80211_key_update_begin(struct ieee80211com *ic)
|
|
{
|
|
ic->ic_crypto.cs_key_update_begin(ic);
|
|
}
|
|
static __inline void
|
|
ieee80211_key_update_end(struct ieee80211com *ic)
|
|
{
|
|
ic->ic_crypto.cs_key_update_end(ic);
|
|
}
|
|
|
|
/*
|
|
* XXX these need to be here for IEEE80211_F_DATAPAD
|
|
*/
|
|
|
|
/*
|
|
* Return the space occupied by the 802.11 header and any
|
|
* padding required by the driver. This works for a
|
|
* management or data frame.
|
|
*/
|
|
static __inline int
|
|
ieee80211_hdrspace(struct ieee80211com *ic, const void *data)
|
|
{
|
|
int size = ieee80211_hdrsize(data);
|
|
if (ic->ic_flags & IEEE80211_F_DATAPAD)
|
|
size = roundup(size, sizeof(u_int32_t));
|
|
return size;
|
|
}
|
|
|
|
/*
|
|
* Like ieee80211_hdrspace, but handles any type of frame.
|
|
*/
|
|
static __inline int
|
|
ieee80211_anyhdrspace(struct ieee80211com *ic, const void *data)
|
|
{
|
|
int size = ieee80211_anyhdrsize(data);
|
|
if (ic->ic_flags & IEEE80211_F_DATAPAD)
|
|
size = roundup(size, sizeof(u_int32_t));
|
|
return size;
|
|
}
|
|
|
|
#define IEEE80211_MSG_DEBUG 0x40000000 /* IFF_DEBUG equivalent */
|
|
#define IEEE80211_MSG_DUMPPKTS 0x20000000 /* IFF_LINK2 equivalant */
|
|
#define IEEE80211_MSG_CRYPTO 0x10000000 /* crypto work */
|
|
#define IEEE80211_MSG_INPUT 0x08000000 /* input handling */
|
|
#define IEEE80211_MSG_XRATE 0x04000000 /* rate set handling */
|
|
#define IEEE80211_MSG_ELEMID 0x02000000 /* element id parsing */
|
|
#define IEEE80211_MSG_NODE 0x01000000 /* node handling */
|
|
#define IEEE80211_MSG_ASSOC 0x00800000 /* association handling */
|
|
#define IEEE80211_MSG_AUTH 0x00400000 /* authentication handling */
|
|
#define IEEE80211_MSG_SCAN 0x00200000 /* scanning */
|
|
#define IEEE80211_MSG_OUTPUT 0x00100000 /* output handling */
|
|
#define IEEE80211_MSG_STATE 0x00080000 /* state machine */
|
|
#define IEEE80211_MSG_POWER 0x00040000 /* power save handling */
|
|
#define IEEE80211_MSG_DOT1X 0x00020000 /* 802.1x authenticator */
|
|
#define IEEE80211_MSG_DOT1XSM 0x00010000 /* 802.1x state machine */
|
|
#define IEEE80211_MSG_RADIUS 0x00008000 /* 802.1x radius client */
|
|
#define IEEE80211_MSG_RADDUMP 0x00004000 /* dump 802.1x radius packets */
|
|
#define IEEE80211_MSG_RADKEYS 0x00002000 /* dump 802.1x keys */
|
|
#define IEEE80211_MSG_WPA 0x00001000 /* WPA/RSN protocol */
|
|
#define IEEE80211_MSG_ACL 0x00000800 /* ACL handling */
|
|
#define IEEE80211_MSG_WME 0x00000400 /* WME protocol */
|
|
#define IEEE80211_MSG_SUPERG 0x00000200 /* Atheros SuperG protocol */
|
|
#define IEEE80211_MSG_DOTH 0x00000100 /* 802.11h support */
|
|
#define IEEE80211_MSG_INACT 0x00000080 /* inactivity handling */
|
|
#define IEEE80211_MSG_ROAM 0x00000040 /* sta-mode roaming */
|
|
|
|
#define IEEE80211_MSG_ANY 0xffffffff /* anything */
|
|
|
|
#ifdef IEEE80211_DEBUG
|
|
#define ieee80211_msg(_ic, _m) ((_ic)->ic_debug & (_m))
|
|
#define IEEE80211_DPRINTF(_ic, _m, _fmt, ...) do { \
|
|
if (ieee80211_msg(_ic, _m)) \
|
|
ieee80211_note(_ic, _fmt, __VA_ARGS__); \
|
|
} while (0)
|
|
#define IEEE80211_NOTE(_ic, _m, _ni, _fmt, ...) do { \
|
|
if (ieee80211_msg(_ic, _m)) \
|
|
ieee80211_note_mac(_ic, (_ni)->ni_macaddr, _fmt, __VA_ARGS__);\
|
|
} while (0)
|
|
#define IEEE80211_NOTE_MAC(_ic, _m, _mac, _fmt, ...) do { \
|
|
if (ieee80211_msg(_ic, _m)) \
|
|
ieee80211_note_mac(_ic, _mac, _fmt, __VA_ARGS__); \
|
|
} while (0)
|
|
#define IEEE80211_NOTE_FRAME(_ic, _m, _wh, _fmt, ...) do { \
|
|
if (ieee80211_msg(_ic, _m)) \
|
|
ieee80211_note_frame(_ic, _wh, _fmt, __VA_ARGS__); \
|
|
} while (0)
|
|
void ieee80211_note(struct ieee80211com *ic, const char *fmt, ...);
|
|
void ieee80211_note_mac(struct ieee80211com *ic,
|
|
const u_int8_t mac[IEEE80211_ADDR_LEN], const char *fmt, ...);
|
|
void ieee80211_note_frame(struct ieee80211com *ic,
|
|
const struct ieee80211_frame *wh, const char *fmt, ...);
|
|
#define ieee80211_msg_debug(_ic) \
|
|
((_ic)->ic_debug & IEEE80211_MSG_DEBUG)
|
|
#define ieee80211_msg_dumppkts(_ic) \
|
|
((_ic)->ic_debug & IEEE80211_MSG_DUMPPKTS)
|
|
#define ieee80211_msg_input(_ic) \
|
|
((_ic)->ic_debug & IEEE80211_MSG_INPUT)
|
|
#define ieee80211_msg_radius(_ic) \
|
|
((_ic)->ic_debug & IEEE80211_MSG_RADIUS)
|
|
#define ieee80211_msg_dumpradius(_ic) \
|
|
((_ic)->ic_debug & IEEE80211_MSG_RADDUMP)
|
|
#define ieee80211_msg_dumpradkeys(_ic) \
|
|
((_ic)->ic_debug & IEEE80211_MSG_RADKEYS)
|
|
#define ieee80211_msg_scan(_ic) \
|
|
((_ic)->ic_debug & IEEE80211_MSG_SCAN)
|
|
#define ieee80211_msg_assoc(_ic) \
|
|
((_ic)->ic_debug & IEEE80211_MSG_ASSOC)
|
|
#else
|
|
#define IEEE80211_DPRINTF(_ic, _m, _fmt, ...)
|
|
#define IEEE80211_NOTE_FRAME(_ic, _m, _wh, _fmt, ...)
|
|
#define IEEE80211_NOTE_MAC(_ic, _m, _mac, _fmt, ...)
|
|
#define ieee80211_msg_dumppkts(_ic) 0
|
|
#define ieee80211_msg(_ic, _m) 0
|
|
#endif
|
|
|
|
#endif /* _NET80211_IEEE80211_VAR_H_ */
|