68e8e04e93
o major overhaul of the way channels are handled: channels are now fully enumerated and uniquely identify the operating characteristics; these changes are visible to user applications which require changes o make scanning support independent of the state machine to enable background scanning and roaming o move scanning support into loadable modules based on the operating mode to enable different policies and reduce the memory footprint on systems w/ constrained resources o add background scanning in station mode (no support for adhoc/ibss mode yet) o significantly speedup sta mode scanning with a variety of techniques o add roaming support when background scanning is supported; for now we use a simple algorithm to trigger a roam: we threshold the rssi and tx rate, if either drops too low we try to roam to a new ap o add tx fragmentation support o add first cut at 802.11n support: this code works with forthcoming drivers but is incomplete; it's included now to establish a baseline for other drivers to be developed and for user applications o adjust max_linkhdr et. al. to reflect 802.11 requirements; this eliminates prepending mbufs for traffic generated locally o add support for Atheros protocol extensions; mainly the fast frames encapsulation (note this can be used with any card that can tx+rx large frames correctly) o add sta support for ap's that beacon both WPA1+2 support o change all data types from bsd-style to posix-style o propagate noise floor data from drivers to net80211 and on to user apps o correct various issues in the sta mode state machine related to handling authentication and association failures o enable the addition of sta mode power save support for drivers that need net80211 support (not in this commit) o remove old WI compatibility ioctls (wicontrol is officially dead) o change the data structures returned for get sta info and get scan results so future additions will not break user apps o fixed tx rate is now maintained internally as an ieee rate and not an index into the rate set; this needs to be extended to deal with multi-mode operation o add extended channel specifications to radiotap to enable 11n sniffing Drivers: o ath: add support for bg scanning, tx fragmentation, fast frames, dynamic turbo (lightly tested), 11n (sniffing only and needs new hal) o awi: compile tested only o ndis: lightly tested o ipw: lightly tested o iwi: add support for bg scanning (well tested but may have some rough edges) o ral, ural, rum: add suppoort for bg scanning, calibrate rssi data o wi: lightly tested This work is based on contributions by Atheros, kmacy, sephe, thompsa, mlaier, kevlo, and others. Much of the scanning work was supported by Atheros. The 11n work was supported by Marvell.
183 lines
7.5 KiB
C
183 lines
7.5 KiB
C
/*-
|
|
* Copyright (c) 2002-2007 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,
|
|
* without modification.
|
|
* 2. Redistributions in binary form must reproduce at minimum a disclaimer
|
|
* similar to the "NO WARRANTY" disclaimer below ("Disclaimer") and any
|
|
* redistribution must be conditioned upon including a substantially
|
|
* similar Disclaimer requirement for further binary redistribution.
|
|
*
|
|
* NO WARRANTY
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
* ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF NONINFRINGEMENT, MERCHANTIBILITY
|
|
* AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
|
|
* THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR 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 DAMAGES.
|
|
*
|
|
* $FreeBSD$
|
|
*/
|
|
|
|
/*
|
|
* Ioctl-related defintions for the Atheros Wireless LAN controller driver.
|
|
*/
|
|
#ifndef _DEV_ATH_ATHIOCTL_H
|
|
#define _DEV_ATH_ATHIOCTL_H
|
|
|
|
struct ath_stats {
|
|
u_int32_t ast_watchdog; /* device reset by watchdog */
|
|
u_int32_t ast_hardware; /* fatal hardware error interrupts */
|
|
u_int32_t ast_bmiss; /* beacon miss interrupts */
|
|
u_int32_t ast_bmiss_phantom;/* beacon miss interrupts */
|
|
u_int32_t ast_bstuck; /* beacon stuck interrupts */
|
|
u_int32_t ast_rxorn; /* rx overrun interrupts */
|
|
u_int32_t ast_rxeol; /* rx eol interrupts */
|
|
u_int32_t ast_txurn; /* tx underrun interrupts */
|
|
u_int32_t ast_mib; /* mib interrupts */
|
|
u_int32_t ast_intrcoal; /* interrupts coalesced */
|
|
u_int32_t ast_tx_packets; /* packet sent on the interface */
|
|
u_int32_t ast_tx_mgmt; /* management frames transmitted */
|
|
u_int32_t ast_tx_discard; /* frames discarded prior to assoc */
|
|
u_int32_t ast_tx_qstop; /* output stopped 'cuz no buffer */
|
|
u_int32_t ast_tx_encap; /* tx encapsulation failed */
|
|
u_int32_t ast_tx_nonode; /* tx failed 'cuz no node */
|
|
u_int32_t ast_tx_nombuf; /* tx failed 'cuz no mbuf */
|
|
u_int32_t ast_tx_nomcl; /* tx failed 'cuz no cluster */
|
|
u_int32_t ast_tx_linear; /* tx linearized to cluster */
|
|
u_int32_t ast_tx_nodata; /* tx discarded empty frame */
|
|
u_int32_t ast_tx_busdma; /* tx failed for dma resrcs */
|
|
u_int32_t ast_tx_xretries;/* tx failed 'cuz too many retries */
|
|
u_int32_t ast_tx_fifoerr; /* tx failed 'cuz FIFO underrun */
|
|
u_int32_t ast_tx_filtered;/* tx failed 'cuz xmit filtered */
|
|
u_int32_t ast_tx_shortretry;/* tx on-chip retries (short) */
|
|
u_int32_t ast_tx_longretry;/* tx on-chip retries (long) */
|
|
u_int32_t ast_tx_badrate; /* tx failed 'cuz bogus xmit rate */
|
|
u_int32_t ast_tx_noack; /* tx frames with no ack marked */
|
|
u_int32_t ast_tx_rts; /* tx frames with rts enabled */
|
|
u_int32_t ast_tx_cts; /* tx frames with cts enabled */
|
|
u_int32_t ast_tx_shortpre;/* tx frames with short preamble */
|
|
u_int32_t ast_tx_altrate; /* tx frames with alternate rate */
|
|
u_int32_t ast_tx_protect; /* tx frames with protection */
|
|
u_int32_t ast_tx_ctsburst;/* tx frames with cts and bursting */
|
|
u_int32_t ast_tx_ctsext; /* tx frames with cts extension */
|
|
u_int32_t ast_rx_nombuf; /* rx setup failed 'cuz no mbuf */
|
|
u_int32_t ast_rx_busdma; /* rx setup failed for dma resrcs */
|
|
u_int32_t ast_rx_orn; /* rx failed 'cuz of desc overrun */
|
|
u_int32_t ast_rx_crcerr; /* rx failed 'cuz of bad CRC */
|
|
u_int32_t ast_rx_fifoerr; /* rx failed 'cuz of FIFO overrun */
|
|
u_int32_t ast_rx_badcrypt;/* rx failed 'cuz decryption */
|
|
u_int32_t ast_rx_badmic; /* rx failed 'cuz MIC failure */
|
|
u_int32_t ast_rx_phyerr; /* rx failed 'cuz of PHY err */
|
|
u_int32_t ast_rx_phy[32]; /* rx PHY error per-code counts */
|
|
u_int32_t ast_rx_tooshort;/* rx discarded 'cuz frame too short */
|
|
u_int32_t ast_rx_toobig; /* rx discarded 'cuz frame too large */
|
|
u_int32_t ast_rx_packets; /* packet recv on the interface */
|
|
u_int32_t ast_rx_mgt; /* management frames received */
|
|
u_int32_t ast_rx_ctl; /* rx discarded 'cuz ctl frame */
|
|
int8_t ast_tx_rssi; /* tx rssi of last ack */
|
|
int8_t ast_rx_rssi; /* rx rssi from histogram */
|
|
u_int8_t ast_tx_rate; /* IEEE rate of last unicast tx */
|
|
u_int32_t ast_be_xmit; /* beacons transmitted */
|
|
u_int32_t ast_be_nombuf; /* beacon setup failed 'cuz no mbuf */
|
|
u_int32_t ast_per_cal; /* periodic calibration calls */
|
|
u_int32_t ast_per_calfail;/* periodic calibration failed */
|
|
u_int32_t ast_per_rfgain; /* periodic calibration rfgain reset */
|
|
u_int32_t ast_rate_calls; /* rate control checks */
|
|
u_int32_t ast_rate_raise; /* rate control raised xmit rate */
|
|
u_int32_t ast_rate_drop; /* rate control dropped xmit rate */
|
|
u_int32_t ast_ant_defswitch;/* rx/default antenna switches */
|
|
u_int32_t ast_ant_txswitch;/* tx antenna switches */
|
|
u_int32_t ast_ant_rx[8]; /* rx frames with antenna */
|
|
u_int32_t ast_ant_tx[8]; /* tx frames with antenna */
|
|
u_int32_t ast_cabq_xmit; /* cabq frames transmitted */
|
|
u_int32_t ast_cabq_busy; /* cabq found busy */
|
|
u_int32_t ast_tx_raw; /* tx frames through raw api */
|
|
u_int32_t ast_ff_txok; /* fast frames tx'd successfully */
|
|
u_int32_t ast_ff_txerr; /* fast frames tx'd w/ error */
|
|
u_int32_t ast_ff_rx; /* fast frames rx'd */
|
|
u_int32_t ast_ff_flush; /* fast frames flushed from staging q */
|
|
u_int32_t ast_tx_qfull; /* tx dropped 'cuz of queue limit */
|
|
int8_t ast_rx_noise; /* rx noise floor */
|
|
u_int32_t ast_pad[22];
|
|
};
|
|
|
|
#define SIOCGATHSTATS _IOWR('i', 137, struct ifreq)
|
|
|
|
struct ath_diag {
|
|
char ad_name[IFNAMSIZ]; /* if name, e.g. "ath0" */
|
|
u_int16_t ad_id;
|
|
#define ATH_DIAG_DYN 0x8000 /* allocate buffer in caller */
|
|
#define ATH_DIAG_IN 0x4000 /* copy in parameters */
|
|
#define ATH_DIAG_OUT 0x0000 /* copy out results (always) */
|
|
#define ATH_DIAG_ID 0x0fff
|
|
u_int16_t ad_in_size; /* pack to fit, yech */
|
|
caddr_t ad_in_data;
|
|
caddr_t ad_out_data;
|
|
u_int ad_out_size;
|
|
|
|
};
|
|
#define SIOCGATHDIAG _IOWR('i', 138, struct ath_diag)
|
|
|
|
/*
|
|
* Radio capture format.
|
|
*/
|
|
#define ATH_RX_RADIOTAP_PRESENT ( \
|
|
(1 << IEEE80211_RADIOTAP_TSFT) | \
|
|
(1 << IEEE80211_RADIOTAP_FLAGS) | \
|
|
(1 << IEEE80211_RADIOTAP_RATE) | \
|
|
(1 << IEEE80211_RADIOTAP_ANTENNA) | \
|
|
(1 << IEEE80211_RADIOTAP_DBM_ANTSIGNAL) | \
|
|
(1 << IEEE80211_RADIOTAP_DBM_ANTNOISE) | \
|
|
(1 << IEEE80211_RADIOTAP_XCHANNEL) | \
|
|
0)
|
|
|
|
struct ath_rx_radiotap_header {
|
|
struct ieee80211_radiotap_header wr_ihdr;
|
|
u_int64_t wr_tsf;
|
|
u_int8_t wr_flags;
|
|
u_int8_t wr_rate;
|
|
int8_t wr_antsignal;
|
|
int8_t wr_antnoise;
|
|
u_int8_t wr_antenna;
|
|
u_int8_t wr_pad[3];
|
|
u_int32_t wr_chan_flags;
|
|
u_int16_t wr_chan_freq;
|
|
u_int8_t wr_chan_ieee;
|
|
int8_t wr_chan_maxpow;
|
|
} __packed;
|
|
|
|
#define ATH_TX_RADIOTAP_PRESENT ( \
|
|
(1 << IEEE80211_RADIOTAP_TSFT) | \
|
|
(1 << IEEE80211_RADIOTAP_FLAGS) | \
|
|
(1 << IEEE80211_RADIOTAP_RATE) | \
|
|
(1 << IEEE80211_RADIOTAP_DBM_TX_POWER) | \
|
|
(1 << IEEE80211_RADIOTAP_ANTENNA) | \
|
|
(1 << IEEE80211_RADIOTAP_XCHANNEL) | \
|
|
0)
|
|
|
|
struct ath_tx_radiotap_header {
|
|
struct ieee80211_radiotap_header wt_ihdr;
|
|
u_int64_t wt_tsf;
|
|
u_int8_t wt_flags;
|
|
u_int8_t wt_rate;
|
|
u_int8_t wt_txpower;
|
|
u_int8_t wt_antenna;
|
|
u_int32_t wt_chan_flags;
|
|
u_int16_t wt_chan_freq;
|
|
u_int8_t wt_chan_ieee;
|
|
int8_t wt_chan_maxpow;
|
|
} __packed;
|
|
|
|
#endif /* _DEV_ATH_ATHIOCTL_H */
|