/*
* Copyright (C) 1999-2011, Broadcom Corporation
*
* Permission to use, copy, modify, and/or distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
* SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
* OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
* CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*
* Fundamental types and constants relating to 802.11
*
* $Id: 802.11.h,v 9.260.2.6 2010-12-15 21:41:14 Exp $
*/
#ifndef _802_11_H_
#define _802_11_H_
#ifndef _TYPEDEFS_H_
#include <typedefs.h>
#endif
#ifndef _NET_ETHERNET_H_
#include <proto/ethernet.h>
#endif
#include <proto/wpa.h>
#include <packed_section_start.h>
#define DOT11_TU_TO_US 1024
#define DOT11_A3_HDR_LEN 24
#define DOT11_A4_HDR_LEN 30
#define DOT11_MAC_HDR_LEN DOT11_A3_HDR_LEN
#define DOT11_FCS_LEN 4
#define DOT11_ICV_LEN 4
#define DOT11_ICV_AES_LEN 8
#define DOT11_QOS_LEN 2
#define DOT11_HTC_LEN 4
#define DOT11_KEY_INDEX_SHIFT 6
#define DOT11_IV_LEN 4
#define DOT11_IV_TKIP_LEN 8
#define DOT11_IV_AES_OCB_LEN 4
#define DOT11_IV_AES_CCM_LEN 8
#define DOT11_IV_MAX_LEN 8
#define DOT11_MAX_MPDU_BODY_LEN 2304
#define DOT11_MAX_MPDU_LEN (DOT11_A4_HDR_LEN + \
DOT11_QOS_LEN + \
DOT11_IV_AES_CCM_LEN + \
DOT11_MAX_MPDU_BODY_LEN + \
DOT11_ICV_LEN + \
DOT11_FCS_LEN)
#define DOT11_MAX_SSID_LEN 32
#define DOT11_DEFAULT_RTS_LEN 2347
#define DOT11_MAX_RTS_LEN 2347
#define DOT11_MIN_FRAG_LEN 256
#define DOT11_MAX_FRAG_LEN 2346
#define DOT11_DEFAULT_FRAG_LEN 2346
#define DOT11_MIN_BEACON_PERIOD 1
#define DOT11_MAX_BEACON_PERIOD 0xFFFF
#define DOT11_MIN_DTIM_PERIOD 1
#define DOT11_MAX_DTIM_PERIOD 0xFF
#define DOT11_LLC_SNAP_HDR_LEN 8
#define DOT11_OUI_LEN 3
BWL_PRE_PACKED_STRUCT struct dot11_llc_snap_header {
uint8 dsap;
uint8 ssap;
uint8 ctl;
uint8 oui[DOT11_OUI_LEN];
uint16 type;
} BWL_POST_PACKED_STRUCT;
#define RFC1042_HDR_LEN (ETHER_HDR_LEN + DOT11_LLC_SNAP_HDR_LEN)
BWL_PRE_PACKED_STRUCT struct dot11_header {
uint16 fc;
uint16 durid;
struct ether_addr a1;
struct ether_addr a2;
struct ether_addr a3;
uint16 seq;
struct ether_addr a4;
} BWL_POST_PACKED_STRUCT;
BWL_PRE_PACKED_STRUCT struct dot11_rts_frame {
uint16 fc;
uint16 durid;
struct ether_addr ra;
struct ether_addr ta;
} BWL_POST_PACKED_STRUCT;
#define DOT11_RTS_LEN 16
BWL_PRE_PACKED_STRUCT struct dot11_cts_frame {
uint16 fc;
uint16 durid;
struct ether_addr ra;
} BWL_POST_PACKED_STRUCT;
#define DOT11_CTS_LEN 10
BWL_PRE_PACKED_STRUCT struct dot11_ack_frame {
uint16 fc;
uint16 durid;
struct ether_addr ra;
} BWL_POST_PACKED_STRUCT;
#define DOT11_ACK_LEN 10
BWL_PRE_PACKED_STRUCT struct dot11_ps_poll_frame {
uint16 fc;
uint16 durid;
struct ether_addr bssid;
struct ether_addr ta;
} BWL_POST_PACKED_STRUCT;
#define DOT11_PS_POLL_LEN 16
BWL_PRE_PACKED_STRUCT struct dot11_cf_end_frame {
uint16 fc;
uint16 durid;
struct ether_addr ra;
struct ether_addr bssid;
} BWL_POST_PACKED_STRUCT;
#define DOT11_CS_END_LEN 16
BWL_PRE_PACKED_STRUCT struct dot11_action_wifi_vendor_specific {
uint8 category;
uint8 OUI[3];
uint8 type;
uint8 subtype;
uint8 data[1040];
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_action_wifi_vendor_specific dot11_action_wifi_vendor_specific_t;
BWL_PRE_PACKED_STRUCT struct dot11_action_vs_frmhdr {
uint8 category;
uint8 OUI[3];
uint8 type;
uint8 subtype;
uint8 data[1];
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_action_vs_frmhdr dot11_action_vs_frmhdr_t;
#define DOT11_ACTION_VS_HDR_LEN 6
#define BCM_ACTION_OUI_BYTE0 0x00
#define BCM_ACTION_OUI_BYTE1 0x90
#define BCM_ACTION_OUI_BYTE2 0x4c
#define DOT11_BA_CTL_POLICY_NORMAL 0x0000
#define DOT11_BA_CTL_POLICY_NOACK 0x0001
#define DOT11_BA_CTL_POLICY_MASK 0x0001
#define DOT11_BA_CTL_MTID 0x0002
#define DOT11_BA_CTL_COMPRESSED 0x0004
#define DOT11_BA_CTL_NUMMSDU_MASK 0x0FC0
#define DOT11_BA_CTL_NUMMSDU_SHIFT 6
#define DOT11_BA_CTL_TID_MASK 0xF000
#define DOT11_BA_CTL_TID_SHIFT 12
BWL_PRE_PACKED_STRUCT struct dot11_ctl_header {
uint16 fc;
uint16 durid;
struct ether_addr ra;
struct ether_addr ta;
} BWL_POST_PACKED_STRUCT;
#define DOT11_CTL_HDR_LEN 16
BWL_PRE_PACKED_STRUCT struct dot11_bar {
uint16 bar_control;
uint16 seqnum;
} BWL_POST_PACKED_STRUCT;
#define DOT11_BAR_LEN 4
#define DOT11_BA_BITMAP_LEN 128
#define DOT11_BA_CMP_BITMAP_LEN 8
BWL_PRE_PACKED_STRUCT struct dot11_ba {
uint16 ba_control;
uint16 seqnum;
uint8 bitmap[DOT11_BA_BITMAP_LEN];
} BWL_POST_PACKED_STRUCT;
#define DOT11_BA_LEN 4
BWL_PRE_PACKED_STRUCT struct dot11_management_header {
uint16 fc;
uint16 durid;
struct ether_addr da;
struct ether_addr sa;
struct ether_addr bssid;
uint16 seq;
} BWL_POST_PACKED_STRUCT;
#define DOT11_MGMT_HDR_LEN 24
BWL_PRE_PACKED_STRUCT struct dot11_bcn_prb {
uint32 timestamp[2];
uint16 beacon_interval;
uint16 capability;
} BWL_POST_PACKED_STRUCT;
#define DOT11_BCN_PRB_LEN 12
#define DOT11_BCN_PRB_FIXED_LEN 12
BWL_PRE_PACKED_STRUCT struct dot11_auth {
uint16 alg;
uint16 seq;
uint16 status;
} BWL_POST_PACKED_STRUCT;
#define DOT11_AUTH_FIXED_LEN 6
BWL_PRE_PACKED_STRUCT struct dot11_assoc_req {
uint16 capability;
uint16 listen;
} BWL_POST_PACKED_STRUCT;
#define DOT11_ASSOC_REQ_FIXED_LEN 4
BWL_PRE_PACKED_STRUCT struct dot11_reassoc_req {
uint16 capability;
uint16 listen;
struct ether_addr ap;
} BWL_POST_PACKED_STRUCT;
#define DOT11_REASSOC_REQ_FIXED_LEN 10
BWL_PRE_PACKED_STRUCT struct dot11_assoc_resp {
uint16 capability;
uint16 status;
uint16 aid;
} BWL_POST_PACKED_STRUCT;
#define DOT11_ASSOC_RESP_FIXED_LEN 6
BWL_PRE_PACKED_STRUCT struct dot11_action_measure {
uint8 category;
uint8 action;
uint8 token;
uint8 data[1];
} BWL_POST_PACKED_STRUCT;
#define DOT11_ACTION_MEASURE_LEN 3
BWL_PRE_PACKED_STRUCT struct dot11_action_ht_ch_width {
uint8 category;
uint8 action;
uint8 ch_width;
} BWL_POST_PACKED_STRUCT;
BWL_PRE_PACKED_STRUCT struct dot11_action_ht_mimops {
uint8 category;
uint8 action;
uint8 control;
} BWL_POST_PACKED_STRUCT;
#define SM_PWRSAVE_ENABLE 1
#define SM_PWRSAVE_MODE 2
BWL_PRE_PACKED_STRUCT struct dot11_power_cnst {
uint8 id;
uint8 len;
uint8 power;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_power_cnst dot11_power_cnst_t;
BWL_PRE_PACKED_STRUCT struct dot11_power_cap {
uint8 min;
uint8 max;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_power_cap dot11_power_cap_t;
BWL_PRE_PACKED_STRUCT struct dot11_tpc_rep {
uint8 id;
uint8 len;
uint8 tx_pwr;
uint8 margin;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_tpc_rep dot11_tpc_rep_t;
#define DOT11_MNG_IE_TPC_REPORT_LEN 2
BWL_PRE_PACKED_STRUCT struct dot11_supp_channels {
uint8 id;
uint8 len;
uint8 first_channel;
uint8 num_channels;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_supp_channels dot11_supp_channels_t;
BWL_PRE_PACKED_STRUCT struct dot11_extch {
uint8 id;
uint8 len;
uint8 extch;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_extch dot11_extch_ie_t;
BWL_PRE_PACKED_STRUCT struct dot11_brcm_extch {
uint8 id;
uint8 len;
uint8 oui[3];
uint8 type;
uint8 extch;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_brcm_extch dot11_brcm_extch_ie_t;
#define BRCM_EXTCH_IE_LEN 5
#define BRCM_EXTCH_IE_TYPE 53
#define DOT11_EXTCH_IE_LEN 1
#define DOT11_EXT_CH_MASK 0x03
#define DOT11_EXT_CH_UPPER 0x01
#define DOT11_EXT_CH_LOWER 0x03
#define DOT11_EXT_CH_NONE 0x00
BWL_PRE_PACKED_STRUCT struct dot11_action_frmhdr {
uint8 category;
uint8 action;
uint8 data[1];
} BWL_POST_PACKED_STRUCT;
#define DOT11_ACTION_FRMHDR_LEN 2
BWL_PRE_PACKED_STRUCT struct dot11_channel_switch {
uint8 id;
uint8 len;
uint8 mode;
uint8 channel;
uint8 count;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_channel_switch dot11_chan_switch_ie_t;
#define DOT11_SWITCH_IE_LEN 3
#define DOT11_CSA_MODE_ADVISORY 0
#define DOT11_CSA_MODE_NO_TX 1
BWL_PRE_PACKED_STRUCT struct dot11_action_switch_channel {
uint8 category;
uint8 action;
dot11_chan_switch_ie_t chan_switch_ie;
dot11_brcm_extch_ie_t extch_ie;
} BWL_POST_PACKED_STRUCT;
BWL_PRE_PACKED_STRUCT struct dot11_csa_body {
uint8 mode;
uint8 reg;
uint8 channel;
uint8 count;
} BWL_POST_PACKED_STRUCT;
BWL_PRE_PACKED_STRUCT struct dot11_ext_csa {
uint8 id;
uint8 len;
struct dot11_csa_body b;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_ext_csa dot11_ext_csa_ie_t;
#define DOT11_EXT_CSA_IE_LEN 4
BWL_PRE_PACKED_STRUCT struct dot11_action_ext_csa {
uint8 category;
uint8 action;
dot11_ext_csa_ie_t chan_switch_ie;
} BWL_POST_PACKED_STRUCT;
BWL_PRE_PACKED_STRUCT struct dot11y_action_ext_csa {
uint8 category;
uint8 action;
struct dot11_csa_body b;
} BWL_POST_PACKED_STRUCT;
BWL_PRE_PACKED_STRUCT struct dot11_obss_coex {
uint8 id;
uint8 len;
uint8 info;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_obss_coex dot11_obss_coex_t;
#define DOT11_OBSS_COEXINFO_LEN 1
#define DOT11_OBSS_COEX_INFO_REQ 0x01
#define DOT11_OBSS_COEX_40MHZ_INTOLERANT 0x02
#define DOT11_OBSS_COEX_20MHZ_WIDTH_REQ 0x04
BWL_PRE_PACKED_STRUCT struct dot11_obss_chanlist {
uint8 id;
uint8 len;
uint8 regclass;
uint8 chanlist[1];
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_obss_chanlist dot11_obss_chanlist_t;
#define DOT11_OBSS_CHANLIST_FIXED_LEN 1
BWL_PRE_PACKED_STRUCT struct dot11_extcap_ie {
uint8 id;
uint8 len;
uint8 cap;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_extcap_ie dot11_extcap_ie_t;
#define DOT11_EXTCAP_LEN 1
#define DOT11_MEASURE_TYPE_BASIC 0
#define DOT11_MEASURE_TYPE_CCA 1
#define DOT11_MEASURE_TYPE_RPI 2
#define DOT11_MEASURE_TYPE_CHLOAD 3
#define DOT11_MEASURE_TYPE_NOISE 4
#define DOT11_MEASURE_TYPE_BEACON 5
#define DOT11_MEASURE_TYPE_FRAME 6
#define DOT11_MEASURE_TYPE_STATS 7
#define DOT11_MEASURE_TYPE_LCI 8
#define DOT11_MEASURE_TYPE_TXSTREAM 9
#define DOT11_MEASURE_TYPE_PAUSE 255
#define DOT11_MEASURE_MODE_PARALLEL (1<<0)
#define DOT11_MEASURE_MODE_ENABLE (1<<1)
#define DOT11_MEASURE_MODE_REQUEST (1<<2)
#define DOT11_MEASURE_MODE_REPORT (1<<3)
#define DOT11_MEASURE_MODE_DUR (1<<4)
#define DOT11_MEASURE_MODE_LATE (1<<0)
#define DOT11_MEASURE_MODE_INCAPABLE (1<<1)
#define DOT11_MEASURE_MODE_REFUSED (1<<2)
#define DOT11_MEASURE_BASIC_MAP_BSS ((uint8)(1<<0))
#define DOT11_MEASURE_BASIC_MAP_OFDM ((uint8)(1<<1))
#define DOT11_MEASURE_BASIC_MAP_UKNOWN ((uint8)(1<<2))
#define DOT11_MEASURE_BASIC_MAP_RADAR ((uint8)(1<<3))
#define DOT11_MEASURE_BASIC_MAP_UNMEAS ((uint8)(1<<4))
BWL_PRE_PACKED_STRUCT struct dot11_meas_req {
uint8 id;
uint8 len;
uint8 token;
uint8 mode;
uint8 type;
uint8 channel;
uint8 start_time[8];
uint16 duration;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_meas_req dot11_meas_req_t;
#define DOT11_MNG_IE_MREQ_LEN 14
#define DOT11_MNG_IE_MREQ_FIXED_LEN 3
BWL_PRE_PACKED_STRUCT struct dot11_meas_rep {
uint8 id;
uint8 len;
uint8 token;
uint8 mode;
uint8 type;
BWL_PRE_PACKED_STRUCT union
{
BWL_PRE_PACKED_STRUCT struct {
uint8 channel;
uint8 start_time[8];
uint16 duration;
uint8 map;
} BWL_POST_PACKED_STRUCT basic;
uint8 data[1];
} BWL_POST_PACKED_STRUCT rep;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_meas_rep dot11_meas_rep_t;
#define DOT11_MNG_IE_MREP_FIXED_LEN 3
BWL_PRE_PACKED_STRUCT struct dot11_meas_rep_basic {
uint8 channel;
uint8 start_time[8];
uint16 duration;
uint8 map;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_meas_rep_basic dot11_meas_rep_basic_t;
#define DOT11_MEASURE_BASIC_REP_LEN 12
BWL_PRE_PACKED_STRUCT struct dot11_quiet {
uint8 id;
uint8 len;
uint8 count;
uint8 period;
uint16 duration;
uint16 offset;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_quiet dot11_quiet_t;
BWL_PRE_PACKED_STRUCT struct chan_map_tuple {
uint8 channel;
uint8 map;
} BWL_POST_PACKED_STRUCT;
typedef struct chan_map_tuple chan_map_tuple_t;
BWL_PRE_PACKED_STRUCT struct dot11_ibss_dfs {
uint8 id;
uint8 len;
uint8 eaddr[ETHER_ADDR_LEN];
uint8 interval;
chan_map_tuple_t map[1];
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_ibss_dfs dot11_ibss_dfs_t;
#define WME_OUI "\x00\x50\xf2"
#define WME_OUI_LEN 3
#define WME_OUI_TYPE 2
#define WME_VER 1
#define WME_TYPE 2
#define WME_SUBTYPE_IE 0
#define WME_SUBTYPE_PARAM_IE 1
#define WME_SUBTYPE_TSPEC 2
#define AC_BE 0
#define AC_BK 1
#define AC_VI 2
#define AC_VO 3
#define AC_COUNT 4
typedef uint8 ac_bitmap_t;
#define AC_BITMAP_NONE 0x0
#define AC_BITMAP_ALL 0xf
#define AC_BITMAP_TST(ab, ac) (((ab) & (1 << (ac))) != 0)
#define AC_BITMAP_SET(ab, ac) (((ab) |= (1 << (ac))))
#define AC_BITMAP_RESET(ab, ac) (((ab) &= ~(1 << (ac))))
BWL_PRE_PACKED_STRUCT struct wme_ie {
uint8 oui[3];
uint8 type;
uint8 subtype;
uint8 version;
uint8 qosinfo;
} BWL_POST_PACKED_STRUCT;
typedef struct wme_ie wme_ie_t;
#define WME_IE_LEN 7
BWL_PRE_PACKED_STRUCT struct edcf_acparam {
uint8 ACI;
uint8 ECW;
uint16 TXOP;
} BWL_POST_PACKED_STRUCT;
typedef struct edcf_acparam edcf_acparam_t;
BWL_PRE_PACKED_STRUCT struct wme_param_ie {
uint8 oui[3];
uint8 type;
uint8 subtype;
uint8 version;
uint8 qosinfo;
uint8 rsvd;
edcf_acparam_t acparam[AC_COUNT];
} BWL_POST_PACKED_STRUCT;
typedef struct wme_param_ie wme_param_ie_t;
#define WME_PARAM_IE_LEN 24
#define WME_QI_AP_APSD_MASK 0x80
#define WME_QI_AP_APSD_SHIFT 7
#define WME_QI_AP_COUNT_MASK 0x0f
#define WME_QI_AP_COUNT_SHIFT 0
#define WME_QI_STA_MAXSPLEN_MASK 0x60
#define WME_QI_STA_MAXSPLEN_SHIFT 5
#define WME_QI_STA_APSD_ALL_MASK 0xf
#define WME_QI_STA_APSD_ALL_SHIFT 0
#define WME_QI_STA_APSD_BE_MASK 0x8
#define WME_QI_STA_APSD_BE_SHIFT 3
#define WME_QI_STA_APSD_BK_MASK 0x4
#define WME_QI_STA_APSD_BK_SHIFT 2
#define WME_QI_STA_APSD_VI_MASK 0x2
#define WME_QI_STA_APSD_VI_SHIFT 1
#define WME_QI_STA_APSD_VO_MASK 0x1
#define WME_QI_STA_APSD_VO_SHIFT 0
#define EDCF_AIFSN_MIN 1
#define EDCF_AIFSN_MAX 15
#define EDCF_AIFSN_MASK 0x0f
#define EDCF_ACM_MASK 0x10
#define EDCF_ACI_MASK 0x60
#define EDCF_ACI_SHIFT 5
#define EDCF_AIFSN_SHIFT 12
#define EDCF_ECW_MIN 0
#define EDCF_ECW_MAX 15
#define EDCF_ECW2CW(exp) ((1 << (exp)) - 1)
#define EDCF_ECWMIN_MASK 0x0f
#define EDCF_ECWMAX_MASK 0xf0
#define EDCF_ECWMAX_SHIFT 4
#define EDCF_TXOP_MIN 0
#define EDCF_TXOP_MAX 65535
#define EDCF_TXOP2USEC(txop) ((txop) << 5)
#define NON_EDCF_AC_BE_ACI_STA 0x02
#define EDCF_AC_BE_ACI_STA 0x03
#define EDCF_AC_BE_ECW_STA 0xA4
#define EDCF_AC_BE_TXOP_STA 0x0000
#define EDCF_AC_BK_ACI_STA 0x27
#define EDCF_AC_BK_ECW_STA 0xA4
#define EDCF_AC_BK_TXOP_STA 0x0000
#define EDCF_AC_VI_ACI_STA 0x42
#define EDCF_AC_VI_ECW_STA 0x43
#define EDCF_AC_VI_TXOP_STA 0x005e
#define EDCF_AC_VO_ACI_STA 0x62
#define EDCF_AC_VO_ECW_STA 0x32
#define EDCF_AC_VO_TXOP_STA 0x002f
#define EDCF_AC_BE_ACI_AP 0x03
#define EDCF_AC_BE_ECW_AP 0x64
#define EDCF_AC_BE_TXOP_AP 0x0000
#define EDCF_AC_BK_ACI_AP 0x27
#define EDCF_AC_BK_ECW_AP 0xA4
#define EDCF_AC_BK_TXOP_AP 0x0000
#define EDCF_AC_VI_ACI_AP 0x41
#define EDCF_AC_VI_ECW_AP 0x43
#define EDCF_AC_VI_TXOP_AP 0x005e
#define EDCF_AC_VO_ACI_AP 0x61
#define EDCF_AC_VO_ECW_AP 0x32
#define EDCF_AC_VO_TXOP_AP 0x002f
BWL_PRE_PACKED_STRUCT struct edca_param_ie {
uint8 qosinfo;
uint8 rsvd;
edcf_acparam_t acparam[AC_COUNT];
} BWL_POST_PACKED_STRUCT;
typedef struct edca_param_ie edca_param_ie_t;
#define EDCA_PARAM_IE_LEN 18
BWL_PRE_PACKED_STRUCT struct qos_cap_ie {
uint8 qosinfo;
} BWL_POST_PACKED_STRUCT;
typedef struct qos_cap_ie qos_cap_ie_t;
BWL_PRE_PACKED_STRUCT struct dot11_qbss_load_ie {
uint8 id;
uint8 length;
uint16 station_count;
uint8 channel_utilization;
uint16 aac;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_qbss_load_ie dot11_qbss_load_ie_t;
#define FIXED_MSDU_SIZE 0x8000
#define MSDU_SIZE_MASK 0x7fff
#define INTEGER_SHIFT 13
#define FRACTION_MASK 0x1FFF
BWL_PRE_PACKED_STRUCT struct dot11_management_notification {
uint8 category;
uint8 action;
uint8 token;
uint8 status;
uint8 data[1];
} BWL_POST_PACKED_STRUCT;
#define DOT11_MGMT_NOTIFICATION_LEN 4
#define WME_ADDTS_REQUEST 0
#define WME_ADDTS_RESPONSE 1
#define WME_DELTS_REQUEST 2
#define WME_ADMISSION_ACCEPTED 0
#define WME_INVALID_PARAMETERS 1
#define WME_ADMISSION_REFUSED 3
#define BCN_PRB_SSID(body) ((char*)(body) + DOT11_BCN_PRB_LEN)
#define DOT11_OPEN_SYSTEM 0
#define DOT11_SHARED_KEY 1
#define DOT11_OPEN_SHARED 2
#define DOT11_FAST_BSS 3
#define DOT11_CHALLENGE_LEN 128
#define FC_PVER_MASK 0x3
#define FC_PVER_SHIFT 0
#define FC_TYPE_MASK 0xC
#define FC_TYPE_SHIFT 2
#define FC_SUBTYPE_MASK 0xF0
#define FC_SUBTYPE_SHIFT 4
#define FC_TODS 0x100
#define FC_TODS_SHIFT 8
#define FC_FROMDS 0x200
#define FC_FROMDS_SHIFT 9
#define FC_MOREFRAG 0x400
#define FC_MOREFRAG_SHIFT 10
#define FC_RETRY 0x800
#define FC_RETRY_SHIFT 11
#define FC_PM 0x1000
#define FC_PM_SHIFT 12
#define FC_MOREDATA 0x2000
#define FC_MOREDATA_SHIFT 13
#define FC_WEP 0x4000
#define FC_WEP_SHIFT 14
#define FC_ORDER 0x8000
#define FC_ORDER_SHIFT 15
#define SEQNUM_SHIFT 4
#define SEQNUM_MAX 0x1000
#define FRAGNUM_MASK 0xF
#define FC_TYPE_MNG 0
#define FC_TYPE_CTL 1
#define FC_TYPE_DATA 2
#define FC_SUBTYPE_ASSOC_REQ 0
#define FC_SUBTYPE_ASSOC_RESP 1
#define FC_SUBTYPE_REASSOC_REQ 2
#define FC_SUBTYPE_REASSOC_RESP 3
#define FC_SUBTYPE_PROBE_REQ 4
#define FC_SUBTYPE_PROBE_RESP 5
#define FC_SUBTYPE_BEACON 8
#define FC_SUBTYPE_ATIM 9
#define FC_SUBTYPE_DISASSOC 10
#define FC_SUBTYPE_AUTH 11
#define FC_SUBTYPE_DEAUTH 12
#define FC_SUBTYPE_ACTION 13
#define FC_SUBTYPE_ACTION_NOACK 14
#define FC_SUBTYPE_CTL_WRAPPER 7
#define FC_SUBTYPE_BLOCKACK_REQ 8
#define FC_SUBTYPE_BLOCKACK 9
#define FC_SUBTYPE_PS_POLL 10
#define FC_SUBTYPE_RTS 11
#define FC_SUBTYPE_CTS 12
#define FC_SUBTYPE_ACK 13
#define FC_SUBTYPE_CF_END 14
#define FC_SUBTYPE_CF_END_ACK 15
#define FC_SUBTYPE_DATA 0
#define FC_SUBTYPE_DATA_CF_ACK 1
#define FC_SUBTYPE_DATA_CF_POLL 2
#define FC_SUBTYPE_DATA_CF_ACK_POLL 3
#define FC_SUBTYPE_NULL 4
#define FC_SUBTYPE_CF_ACK 5
#define FC_SUBTYPE_CF_POLL 6
#define FC_SUBTYPE_CF_ACK_POLL 7
#define FC_SUBTYPE_QOS_DATA 8
#define FC_SUBTYPE_QOS_DATA_CF_ACK 9
#define FC_SUBTYPE_QOS_DATA_CF_POLL 10
#define FC_SUBTYPE_QOS_DATA_CF_ACK_POLL 11
#define FC_SUBTYPE_QOS_NULL 12
#define FC_SUBTYPE_QOS_CF_POLL 14
#define FC_SUBTYPE_QOS_CF_ACK_POLL 15
#define FC_SUBTYPE_ANY_QOS(s) (((s) & 8) != 0)
#define FC_SUBTYPE_ANY_NULL(s) (((s) & 4) != 0)
#define FC_SUBTYPE_ANY_CF_POLL(s) (((s) & 2) != 0)
#define FC_SUBTYPE_ANY_CF_ACK(s) (((s) & 1) != 0)
#define FC_KIND_MASK (FC_TYPE_MASK | FC_SUBTYPE_MASK)
#define FC_KIND(t, s) (((t) << FC_TYPE_SHIFT) | ((s) << FC_SUBTYPE_SHIFT))
#define FC_SUBTYPE(fc) (((fc) & FC_SUBTYPE_MASK) >> FC_SUBTYPE_SHIFT)
#define FC_TYPE(fc) (((fc) & FC_TYPE_MASK) >> FC_TYPE_SHIFT)
#define FC_ASSOC_REQ FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_ASSOC_REQ)
#define FC_ASSOC_RESP FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_ASSOC_RESP)
#define FC_REASSOC_REQ FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_REASSOC_REQ)
#define FC_REASSOC_RESP FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_REASSOC_RESP)
#define FC_PROBE_REQ FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_PROBE_REQ)
#define FC_PROBE_RESP FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_PROBE_RESP)
#define FC_BEACON FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_BEACON)
#define FC_DISASSOC FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_DISASSOC)
#define FC_AUTH FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_AUTH)
#define FC_DEAUTH FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_DEAUTH)
#define FC_ACTION FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_ACTION)
#define FC_ACTION_NOACK FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_ACTION_NOACK)
#define FC_CTL_WRAPPER FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_CTL_WRAPPER)
#define FC_BLOCKACK_REQ FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_BLOCKACK_REQ)
#define FC_BLOCKACK FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_BLOCKACK)
#define FC_PS_POLL FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_PS_POLL)
#define FC_RTS FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_RTS)
#define FC_CTS FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_CTS)
#define FC_ACK FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_ACK)
#define FC_CF_END FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_CF_END)
#define FC_CF_END_ACK FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_CF_END_ACK)
#define FC_DATA FC_KIND(FC_TYPE_DATA, FC_SUBTYPE_DATA)
#define FC_NULL_DATA FC_KIND(FC_TYPE_DATA, FC_SUBTYPE_NULL)
#define FC_DATA_CF_ACK FC_KIND(FC_TYPE_DATA, FC_SUBTYPE_DATA_CF_ACK)
#define FC_QOS_DATA FC_KIND(FC_TYPE_DATA, FC_SUBTYPE_QOS_DATA)
#define FC_QOS_NULL FC_KIND(FC_TYPE_DATA, FC_SUBTYPE_QOS_NULL)
#define QOS_PRIO_SHIFT 0
#define QOS_PRIO_MASK 0x0007
#define QOS_PRIO(qos) (((qos) & QOS_PRIO_MASK) >> QOS_PRIO_SHIFT)
#define QOS_TID_SHIFT 0
#define QOS_TID_MASK 0x000f
#define QOS_TID(qos) (((qos) & QOS_TID_MASK) >> QOS_TID_SHIFT)
#define QOS_EOSP_SHIFT 4
#define QOS_EOSP_MASK 0x0010
#define QOS_EOSP(qos) (((qos) & QOS_EOSP_MASK) >> QOS_EOSP_SHIFT)
#define QOS_ACK_NORMAL_ACK 0
#define QOS_ACK_NO_ACK 1
#define QOS_ACK_NO_EXP_ACK 2
#define QOS_ACK_BLOCK_ACK 3
#define QOS_ACK_SHIFT 5
#define QOS_ACK_MASK 0x0060
#define QOS_ACK(qos) (((qos) & QOS_ACK_MASK) >> QOS_ACK_SHIFT)
#define QOS_AMSDU_SHIFT 7
#define QOS_AMSDU_MASK 0x0080
#define DOT11_MNG_AUTH_ALGO_LEN 2
#define DOT11_MNG_AUTH_SEQ_LEN 2
#define DOT11_MNG_BEACON_INT_LEN 2
#define DOT11_MNG_CAP_LEN 2
#define DOT11_MNG_AP_ADDR_LEN 6
#define DOT11_MNG_LISTEN_INT_LEN 2
#define DOT11_MNG_REASON_LEN 2
#define DOT11_MNG_AID_LEN 2
#define DOT11_MNG_STATUS_LEN 2
#define DOT11_MNG_TIMESTAMP_LEN 8
#define DOT11_AID_MASK 0x3fff
#define DOT11_RC_RESERVED 0
#define DOT11_RC_UNSPECIFIED 1
#define DOT11_RC_AUTH_INVAL 2
#define DOT11_RC_DEAUTH_LEAVING 3
#define DOT11_RC_INACTIVITY 4
#define DOT11_RC_BUSY 5
#define DOT11_RC_INVAL_CLASS_2 6
#define DOT11_RC_INVAL_CLASS_3 7
#define DOT11_RC_DISASSOC_LEAVING 8
#define DOT11_RC_NOT_AUTH 9
#define DOT11_RC_BAD_PC 10
#define DOT11_RC_BAD_CHANNELS 11
#define DOT11_RC_UNSPECIFIED_QOS 32
#define DOT11_RC_INSUFFCIENT_BW 33
#define DOT11_RC_EXCESSIVE_FRAMES 34
#define DOT11_RC_TX_OUTSIDE_TXOP 35
#define DOT11_RC_LEAVING_QBSS 36
#define DOT11_RC_BAD_MECHANISM 37
#define DOT11_RC_SETUP_NEEDED 38
#define DOT11_RC_TIMEOUT 39
#define DOT11_RC_MAX 23
#define DOT11_SC_SUCCESS 0
#define DOT11_SC_FAILURE 1
#define DOT11_SC_CAP_MISMATCH 10
#define DOT11_SC_REASSOC_FAIL 11
#define DOT11_SC_ASSOC_FAIL 12
#define DOT11_SC_AUTH_MISMATCH 13
#define DOT11_SC_AUTH_SEQ 14
#define DOT11_SC_AUTH_CHALLENGE_FAIL 15
#define DOT11_SC_AUTH_TIMEOUT 16
#define DOT11_SC_ASSOC_BUSY_FAIL 17
#define DOT11_SC_ASSOC_RATE_MISMATCH 18
#define DOT11_SC_ASSOC_SHORT_REQUIRED 19
#define DOT11_SC_ASSOC_PBCC_REQUIRED 20
#define DOT11_SC_ASSOC_AGILITY_REQUIRED 21
#define DOT11_SC_ASSOC_SPECTRUM_REQUIRED 22
#define DOT11_SC_ASSOC_BAD_POWER_CAP 23
#define DOT11_SC_ASSOC_BAD_SUP_CHANNELS 24
#define DOT11_SC_ASSOC_SHORTSLOT_REQUIRED 25
#define DOT11_SC_ASSOC_ERPBCC_REQUIRED 26
#define DOT11_SC_ASSOC_DSSOFDM_REQUIRED 27
#define DOT11_SC_DECLINED 37
#define DOT11_SC_INVALID_PARAMS 38
#define DOT11_SC_INVALID_AKMP 43
#define DOT11_SC_INVALID_MDID 54
#define DOT11_SC_INVALID_FTIE 55
#define DOT11_MNG_DS_PARAM_LEN 1
#define DOT11_MNG_IBSS_PARAM_LEN 2
#define DOT11_MNG_TIM_FIXED_LEN 3
#define DOT11_MNG_TIM_DTIM_COUNT 0
#define DOT11_MNG_TIM_DTIM_PERIOD 1
#define DOT11_MNG_TIM_BITMAP_CTL 2
#define DOT11_MNG_TIM_PVB 3
#define TLV_TAG_OFF 0
#define TLV_LEN_OFF 1
#define TLV_HDR_LEN 2
#define TLV_BODY_OFF 2
#define DOT11_MNG_SSID_ID 0
#define DOT11_MNG_RATES_ID 1
#define DOT11_MNG_FH_PARMS_ID 2
#define DOT11_MNG_DS_PARMS_ID 3
#define DOT11_MNG_CF_PARMS_ID 4
#define DOT11_MNG_TIM_ID 5
#define DOT11_MNG_IBSS_PARMS_ID 6
#define DOT11_MNG_COUNTRY_ID 7
#define DOT11_MNG_HOPPING_PARMS_ID 8
#define DOT11_MNG_HOPPING_TABLE_ID 9
#define DOT11_MNG_REQUEST_ID 10
#define DOT11_MNG_QBSS_LOAD_ID 11
#define DOT11_MNG_EDCA_PARAM_ID 12
#define DOT11_MNG_CHALLENGE_ID 16
#define DOT11_MNG_PWR_CONSTRAINT_ID 32
#define DOT11_MNG_PWR_CAP_ID 33
#define DOT11_MNG_TPC_REQUEST_ID 34
#define DOT11_MNG_TPC_REPORT_ID 35
#define DOT11_MNG_SUPP_CHANNELS_ID 36
#define DOT11_MNG_CHANNEL_SWITCH_ID 37
#define DOT11_MNG_MEASURE_REQUEST_ID 38
#define DOT11_MNG_MEASURE_REPORT_ID 39
#define DOT11_MNG_QUIET_ID 40
#define DOT11_MNG_IBSS_DFS_ID 41
#define DOT11_MNG_ERP_ID 42
#define DOT11_MNG_TS_DELAY_ID 43
#define DOT11_MNG_HT_CAP 45
#define DOT11_MNG_QOS_CAP_ID 46
#define DOT11_MNG_NONERP_ID 47
#define DOT11_MNG_RSN_ID 48
#define DOT11_MNG_EXT_RATES_ID 50
#define DOT11_MNG_AP_CHREP_ID 51
#define DOT11_MNG_NBR_REP_ID 52
#define DOT11_MNG_MDIE_ID 54
#define DOT11_MNG_FTIE_ID 55
#define DOT11_MNG_FT_TI_ID 56
#define DOT11_MNG_REGCLASS_ID 59
#define DOT11_MNG_EXT_CSA_ID 60
#define DOT11_MNG_HT_ADD 61
#define DOT11_MNG_EXT_CHANNEL_OFFSET 62
#define DOT11_MNG_RRM_CAP_ID 70
#define DOT11_MNG_HT_BSS_COEXINFO_ID 72
#define DOT11_MNG_HT_BSS_CHANNEL_REPORT_ID 73
#define DOT11_MNG_HT_OBSS_ID 74
#define DOT11_MNG_EXT_CAP 127
#define DOT11_MNG_WPA_ID 221
#define DOT11_MNG_PROPR_ID 221
#define DOT11_MNG_VS_ID 221
#define DOT11_RATE_BASIC 0x80
#define DOT11_RATE_MASK 0x7F
#define DOT11_MNG_ERP_LEN 1
#define DOT11_MNG_NONERP_PRESENT 0x01
#define DOT11_MNG_USE_PROTECTION 0x02
#define DOT11_MNG_BARKER_PREAMBLE 0x04
#define DOT11_MGN_TS_DELAY_LEN 4
#define TS_DELAY_FIELD_SIZE 4
#define DOT11_CAP_ESS 0x0001
#define DOT11_CAP_IBSS 0x0002
#define DOT11_CAP_POLLABLE 0x0004
#define DOT11_CAP_POLL_RQ 0x0008
#define DOT11_CAP_PRIVACY 0x0010
#define DOT11_CAP_SHORT 0x0020
#define DOT11_CAP_PBCC 0x0040
#define DOT11_CAP_AGILITY 0x0080
#define DOT11_CAP_SPECTRUM 0x0100
#define DOT11_CAP_SHORTSLOT 0x0400
#define DOT11_CAP_RRM 0x1000
#define DOT11_CAP_CCK_OFDM 0x2000
#define DOT11_OBSS_COEX_MNG_SUPPORT 0x01
#define DOT11_ACTION_HDR_LEN 2
#define DOT11_ACTION_CAT_OFF 0
#define DOT11_ACTION_ACT_OFF 1
#define DOT11_ACTION_CAT_ERR_MASK 0x80
#define DOT11_ACTION_CAT_MASK 0x7F
#define DOT11_ACTION_CAT_SPECT_MNG 0
#define DOT11_ACTION_CAT_QOS 1
#define DOT11_ACTION_CAT_DLS 2
#define DOT11_ACTION_CAT_BLOCKACK 3
#define DOT11_ACTION_CAT_PUBLIC 4
#define DOT11_ACTION_CAT_RRM 5
#define DOT11_ACTION_CAT_FBT 6
#define DOT11_ACTION_CAT_HT 7
#define DOT11_ACTION_CAT_BSSMGMT 10
#define DOT11_ACTION_NOTIFICATION 17
#define DOT11_ACTION_CAT_VS 127
#define DOT11_SM_ACTION_M_REQ 0
#define DOT11_SM_ACTION_M_REP 1
#define DOT11_SM_ACTION_TPC_REQ 2
#define DOT11_SM_ACTION_TPC_REP 3
#define DOT11_SM_ACTION_CHANNEL_SWITCH 4
#define DOT11_SM_ACTION_EXT_CSA 5
#define DOT11_ACTION_ID_HT_CH_WIDTH 0
#define DOT11_ACTION_ID_HT_MIMO_PS 1
#define DOT11_PUB_ACTION_BSS_COEX_MNG 0
#define DOT11_PUB_ACTION_CHANNEL_SWITCH 4
#define DOT11_BA_ACTION_ADDBA_REQ 0
#define DOT11_BA_ACTION_ADDBA_RESP 1
#define DOT11_BA_ACTION_DELBA 2
#define DOT11_ADDBA_PARAM_AMSDU_SUP 0x0001
#define DOT11_ADDBA_PARAM_POLICY_MASK 0x0002
#define DOT11_ADDBA_PARAM_POLICY_SHIFT 1
#define DOT11_ADDBA_PARAM_TID_MASK 0x003c
#define DOT11_ADDBA_PARAM_TID_SHIFT 2
#define DOT11_ADDBA_PARAM_BSIZE_MASK 0xffc0
#define DOT11_ADDBA_PARAM_BSIZE_SHIFT 6
#define DOT11_ADDBA_POLICY_DELAYED 0
#define DOT11_ADDBA_POLICY_IMMEDIATE 1
BWL_PRE_PACKED_STRUCT struct dot11_addba_req {
uint8 category;
uint8 action;
uint8 token;
uint16 addba_param_set;
uint16 timeout;
uint16 start_seqnum;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_addba_req dot11_addba_req_t;
#define DOT11_ADDBA_REQ_LEN 9
BWL_PRE_PACKED_STRUCT struct dot11_addba_resp {
uint8 category;
uint8 action;
uint8 token;
uint16 status;
uint16 addba_param_set;
uint16 timeout;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_addba_resp dot11_addba_resp_t;
#define DOT11_ADDBA_RESP_LEN 9
#define DOT11_DELBA_PARAM_INIT_MASK 0x0800
#define DOT11_DELBA_PARAM_INIT_SHIFT 11
#define DOT11_DELBA_PARAM_TID_MASK 0xf000
#define DOT11_DELBA_PARAM_TID_SHIFT 12
BWL_PRE_PACKED_STRUCT struct dot11_delba {
uint8 category;
uint8 action;
uint16 delba_param_set;
uint16 reason;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_delba dot11_delba_t;
#define DOT11_DELBA_LEN 6
#define DOT11_RRM_CAP_LEN 5
BWL_PRE_PACKED_STRUCT struct dot11_rrm_cap_ie {
uint8 cap[DOT11_RRM_CAP_LEN];
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_rrm_cap_ie dot11_rrm_cap_ie_t;
#define DOT11_RRM_CAP_LINK 0
#define DOT11_RRM_CAP_NEIGHBOR_REPORT 1
#define DOT11_RRM_CAP_PARALLEL 2
#define DOT11_RRM_CAP_REPEATED 3
#define DOT11_RRM_CAP_BCN_PASSIVE 4
#define DOT11_RRM_CAP_BCN_ACTIVE 5
#define DOT11_RRM_CAP_BCN_TABLE 6
#define DOT11_RRM_CAP_BCN_REP_COND 7
#define DOT11_RRM_CAP_AP_CHANREP 16
#define DOT11_RM_ACTION_RM_REQ 0
#define DOT11_RM_ACTION_RM_REP 1
#define DOT11_RM_ACTION_LM_REQ 2
#define DOT11_RM_ACTION_LM_REP 3
#define DOT11_RM_ACTION_NR_REQ 4
#define DOT11_RM_ACTION_NR_REP 5
BWL_PRE_PACKED_STRUCT struct dot11_rm_action {
uint8 category;
uint8 action;
uint8 token;
uint8 data[1];
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_rm_action dot11_rm_action_t;
#define DOT11_RM_ACTION_LEN 3
BWL_PRE_PACKED_STRUCT struct dot11_rmreq {
uint8 category;
uint8 action;
uint8 token;
uint16 reps;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_rmreq dot11_rmreq_t;
#define DOT11_RMREQ_LEN 5
BWL_PRE_PACKED_STRUCT struct dot11_rm_ie {
uint8 id;
uint8 len;
uint8 token;
uint8 mode;
uint8 type;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_rm_ie dot11_rm_ie_t;
#define DOT11_RM_IE_LEN 5
#define DOT11_RMREQ_MODE_PARALLEL 1
#define DOT11_RMREQ_MODE_ENABLE 2
#define DOT11_RMREQ_MODE_REQUEST 4
#define DOT11_RMREQ_MODE_REPORT 8
#define DOT11_RMREQ_MODE_DURMAND 0x10
#define DOT11_RMREP_MODE_LATE 1
#define DOT11_RMREP_MODE_INCAPABLE 2
#define DOT11_RMREP_MODE_REFUSED 4
BWL_PRE_PACKED_STRUCT struct dot11_rmreq_bcn {
uint8 id;
uint8 len;
uint8 token;
uint8 mode;
uint8 type;
uint8 reg;
uint8 channel;
uint16 interval;
uint16 duration;
uint8 bcn_mode;
struct ether_addr bssid;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_rmreq_bcn dot11_rmreq_bcn_t;
#define DOT11_RMREQ_BCN_LEN 18
BWL_PRE_PACKED_STRUCT struct dot11_rmrep_bcn {
uint8 reg;
uint8 channel;
uint32 starttime[2];
uint16 duration;
uint8 frame_info;
uint8 rcpi;
uint8 rsni;
struct ether_addr bssid;
uint8 antenna_id;
uint32 parent_tsf;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_rmrep_bcn dot11_rmrep_bcn_t;
#define DOT11_RMREP_BCN_LEN 26
#define DOT11_RMREQ_BCN_PASSIVE 0
#define DOT11_RMREQ_BCN_ACTIVE 1
#define DOT11_RMREQ_BCN_TABLE 2
#define DOT11_RMREQ_BCN_SSID_ID 0
#define DOT11_RMREQ_BCN_REPINFO_ID 1
#define DOT11_RMREQ_BCN_REPDET_ID 2
#define DOT11_RMREQ_BCN_REQUEST_ID 10
#define DOT11_RMREQ_BCN_APCHREP_ID 51
#define DOT11_RMREQ_BCN_REPDET_FIXED 0
#define DOT11_RMREQ_BCN_REPDET_REQUEST 1
#define DOT11_RMREQ_BCN_REPDET_ALL 2
#define DOT11_RMREP_BCN_FRM_BODY 1
BWL_PRE_PACKED_STRUCT struct dot11_rmrep_nbr {
struct ether_addr bssid;
uint32 bssid_info;
uint8 reg;
uint8 channel;
uint8 phytype;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_rmrep_nbr dot11_rmrep_nbr_t;
#define DOT11_RMREP_NBR_LEN 13
#define DOT11_BSSTYPE_INFRASTRUCTURE 0
#define DOT11_BSSTYPE_INDEPENDENT 1
#define DOT11_BSSTYPE_ANY 2
#define DOT11_SCANTYPE_ACTIVE 0
#define DOT11_SCANTYPE_PASSIVE 1
BWL_PRE_PACKED_STRUCT struct dot11_lmreq {
uint8 category;
uint8 action;
uint8 token;
uint8 txpwr;
uint8 maxtxpwr;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_lmreq dot11_lmreq_t;
#define DOT11_LMREQ_LEN 5
BWL_PRE_PACKED_STRUCT struct dot11_lmrep {
uint8 category;
uint8 action;
uint8 token;
dot11_tpc_rep_t tpc;
uint8 rxant;
uint8 txant;
uint8 rcpi;
uint8 rsni;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_lmrep dot11_lmrep_t;
#define DOT11_LMREP_LEN 11
#define PREN_PREAMBLE 24
#define PREN_MM_EXT 12
#define PREN_PREAMBLE_EXT 4
#define RIFS_11N_TIME 2
#define HT_SIG1_MCS_MASK 0x00007F
#define HT_SIG1_CBW 0x000080
#define HT_SIG1_HT_LENGTH 0xFFFF00
#define HT_SIG2_SMOOTHING 0x000001
#define HT_SIG2_NOT_SOUNDING 0x000002
#define HT_SIG2_RESERVED 0x000004
#define HT_SIG2_AGGREGATION 0x000008
#define HT_SIG2_STBC_MASK 0x000030
#define HT_SIG2_STBC_SHIFT 4
#define HT_SIG2_FEC_CODING 0x000040
#define HT_SIG2_SHORT_GI 0x000080
#define HT_SIG2_ESS_MASK 0x000300
#define HT_SIG2_ESS_SHIFT 8
#define HT_SIG2_CRC 0x03FC00
#define HT_SIG2_TAIL 0x1C0000
#define APHY_SLOT_TIME 9
#define APHY_SIFS_TIME 16
#define APHY_DIFS_TIME (APHY_SIFS_TIME + (2 * APHY_SLOT_TIME))
#define APHY_PREAMBLE_TIME 16
#define APHY_SIGNAL_TIME 4
#define APHY_SYMBOL_TIME 4
#define APHY_SERVICE_NBITS 16
#define APHY_TAIL_NBITS 6
#define APHY_CWMIN 15
#define BPHY_SLOT_TIME 20
#define BPHY_SIFS_TIME 10
#define BPHY_DIFS_TIME 50
#define BPHY_PLCP_TIME 192
#define BPHY_PLCP_SHORT_TIME 96
#define BPHY_CWMIN 31
#define DOT11_OFDM_SIGNAL_EXTENSION 6
#define PHY_CWMAX 1023
#define DOT11_MAXNUMFRAGS 16
typedef struct d11cnt {
uint32 txfrag;
uint32 txmulti;
uint32 txfail;
uint32 txretry;
uint32 txretrie;
uint32 rxdup;
uint32 txrts;
uint32 txnocts;
uint32 txnoack;
uint32 rxfrag;
uint32 rxmulti;
uint32 rxcrc;
uint32 txfrmsnt;
uint32 rxundec;
} d11cnt_t;
#define BRCM_PROP_OUI "\x00\x90\x4C"
#define BRCM_OUI "\x00\x10\x18"
BWL_PRE_PACKED_STRUCT struct brcm_ie {
uint8 id;
uint8 len;
uint8 oui[3];
uint8 ver;
uint8 assoc;
uint8 flags;
uint8 flags1;
uint16 amsdu_mtu_pref;
} BWL_POST_PACKED_STRUCT;
typedef struct brcm_ie brcm_ie_t;
#define BRCM_IE_LEN 11
#define BRCM_IE_VER 2
#define BRCM_IE_LEGACY_AES_VER 1
#ifdef WLAFTERBURNER
#define BRF_ABCAP 0x1
#define BRF_ABRQRD 0x2
#define BRF_ABCOUNTER_MASK 0xf0
#define BRF_ABCOUNTER_SHIFT 4
#endif
#define BRF_LZWDS 0x4
#define BRF_BLOCKACK 0x8
#define BRF1_AMSDU 0x1
#define BRF1_WMEPS 0x4
#define BRF1_PSOFIX 0x8
#define BRF1_RX_LARGE_AGG 0x10
#define BRF1_SOFTAP 0x40
#ifdef WLAFTERBURNER
#define AB_WDS_TIMEOUT_MAX 15
#define AB_WDS_TIMEOUT_MIN 1
#endif
#define AB_GUARDCOUNT 10
BWL_PRE_PACKED_STRUCT struct vndr_ie {
uchar id;
uchar len;
uchar oui [3];
uchar data [1];
} BWL_POST_PACKED_STRUCT;
typedef struct vndr_ie vndr_ie_t;
#define VNDR_IE_HDR_LEN 2
#define VNDR_IE_MIN_LEN 3
#define VNDR_IE_MAX_LEN 256
#define MCSSET_LEN 16
#define MAX_MCS_NUM (128)
BWL_PRE_PACKED_STRUCT struct ht_cap_ie {
uint16 cap;
uint8 params;
uint8 supp_mcs[MCSSET_LEN];
uint16 ext_htcap;
uint32 txbf_cap;
uint8 as_cap;
} BWL_POST_PACKED_STRUCT;
typedef struct ht_cap_ie ht_cap_ie_t;
BWL_PRE_PACKED_STRUCT struct ht_prop_cap_ie {
uint8 id;
uint8 len;
uint8 oui[3];
uint8 type;
ht_cap_ie_t cap_ie;
} BWL_POST_PACKED_STRUCT;
typedef struct ht_prop_cap_ie ht_prop_cap_ie_t;
#define HT_PROP_IE_OVERHEAD 4
#define HT_CAP_IE_LEN 26
#define HT_CAP_IE_TYPE 51
#define HT_CAP_LDPC_CODING 0x0001
#define HT_CAP_40MHZ 0x0002
#define HT_CAP_MIMO_PS_MASK 0x000C
#define HT_CAP_MIMO_PS_SHIFT 0x0002
#define HT_CAP_MIMO_PS_OFF 0x0003
#define HT_CAP_MIMO_PS_RTS 0x0001
#define HT_CAP_MIMO_PS_ON 0x0000
#define HT_CAP_GF 0x0010
#define HT_CAP_SHORT_GI_20 0x0020
#define HT_CAP_SHORT_GI_40 0x0040
#define HT_CAP_TX_STBC 0x0080
#define HT_CAP_RX_STBC_MASK 0x0300
#define HT_CAP_RX_STBC_SHIFT 8
#define HT_CAP_DELAYED_BA 0x0400
#define HT_CAP_MAX_AMSDU 0x0800
#define HT_CAP_DSSS_CCK 0x1000
#define HT_CAP_PSMP 0x2000
#define HT_CAP_40MHZ_INTOLERANT 0x4000
#define HT_CAP_LSIG_TXOP 0x8000
#define HT_CAP_RX_STBC_NO 0x0
#define HT_CAP_RX_STBC_ONE_STREAM 0x1
#define HT_CAP_RX_STBC_TWO_STREAM 0x2
#define HT_CAP_RX_STBC_THREE_STREAM 0x3
#define HT_MAX_AMSDU 7935
#define HT_MIN_AMSDU 3835
#define HT_PARAMS_RX_FACTOR_MASK 0x03
#define HT_PARAMS_DENSITY_MASK 0x1C
#define HT_PARAMS_DENSITY_SHIFT 2
#define AMPDU_MAX_MPDU_DENSITY 7
#define AMPDU_RX_FACTOR_8K 0
#define AMPDU_RX_FACTOR_16K 1
#define AMPDU_RX_FACTOR_32K 2
#define AMPDU_RX_FACTOR_64K 3
#define AMPDU_RX_FACTOR_BASE 8*1024
#define AMPDU_DELIMITER_LEN 4
#define AMPDU_DELIMITER_LEN_MAX 63
BWL_PRE_PACKED_STRUCT struct ht_add_ie {
uint8 ctl_ch;
uint8 byte1;
uint16 opmode;
uint16 misc_bits;
uint8 basic_mcs[MCSSET_LEN];
} BWL_POST_PACKED_STRUCT;
typedef struct ht_add_ie ht_add_ie_t;
BWL_PRE_PACKED_STRUCT struct ht_prop_add_ie {
uint8 id;
uint8 len;
uint8 oui[3];
uint8 type;
ht_add_ie_t add_ie;
} BWL_POST_PACKED_STRUCT;
typedef struct ht_prop_add_ie ht_prop_add_ie_t;
#define HT_ADD_IE_LEN 22
#define HT_ADD_IE_TYPE 52
#define HT_BW_ANY 0x04
#define HT_RIFS_PERMITTED 0x08
#define HT_OPMODE_MASK 0x0003
#define HT_OPMODE_SHIFT 0
#define HT_OPMODE_PURE 0x0000
#define HT_OPMODE_OPTIONAL 0x0001
#define HT_OPMODE_HT20IN40 0x0002
#define HT_OPMODE_MIXED 0x0003
#define HT_OPMODE_NONGF 0x0004
#define DOT11N_TXBURST 0x0008
#define DOT11N_OBSS_NONHT 0x0010
#define HT_BASIC_STBC_MCS 0x007f
#define HT_DUAL_STBC_PROT 0x0080
#define HT_SECOND_BCN 0x0100
#define HT_LSIG_TXOP 0x0200
#define HT_PCO_ACTIVE 0x0400
#define HT_PCO_PHASE 0x0800
#define DOT11N_2G_TXBURST_LIMIT 6160
#define DOT11N_5G_TXBURST_LIMIT 3080
#define GET_HT_OPMODE(add_ie) ((ltoh16_ua(&add_ie->opmode) & HT_OPMODE_MASK) \
>> HT_OPMODE_SHIFT)
#define HT_MIXEDMODE_PRESENT(add_ie) ((ltoh16_ua(&add_ie->opmode) & HT_OPMODE_MASK) \
== HT_OPMODE_MIXED)
#define HT_HT20_PRESENT(add_ie) ((ltoh16_ua(&add_ie->opmode) & HT_OPMODE_MASK) \
== HT_OPMODE_HT20IN40)
#define HT_OPTIONAL_PRESENT(add_ie) ((ltoh16_ua(&add_ie->opmode) & HT_OPMODE_MASK) \
== HT_OPMODE_OPTIONAL)
#define HT_USE_PROTECTION(add_ie) (HT_HT20_PRESENT((add_ie)) || \
HT_MIXEDMODE_PRESENT((add_ie)))
#define HT_NONGF_PRESENT(add_ie) ((ltoh16_ua(&add_ie->opmode) & HT_OPMODE_NONGF) \
== HT_OPMODE_NONGF)
#define DOT11N_TXBURST_PRESENT(add_ie) ((ltoh16_ua(&add_ie->opmode) & DOT11N_TXBURST) \
== DOT11N_TXBURST)
#define DOT11N_OBSS_NONHT_PRESENT(add_ie) ((ltoh16_ua(&add_ie->opmode) & DOT11N_OBSS_NONHT) \
== DOT11N_OBSS_NONHT)
BWL_PRE_PACKED_STRUCT struct obss_params {
uint16 passive_dwell;
uint16 active_dwell;
uint16 bss_widthscan_interval;
uint16 passive_total;
uint16 active_total;
uint16 chanwidth_transition_dly;
uint16 activity_threshold;
} BWL_POST_PACKED_STRUCT;
typedef struct obss_params obss_params_t;
BWL_PRE_PACKED_STRUCT struct dot11_obss_ie {
uint8 id;
uint8 len;
obss_params_t obss_params;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_obss_ie dot11_obss_ie_t;
#define DOT11_OBSS_SCAN_IE_LEN sizeof(obss_params_t)
#define HT_CTRL_LA_TRQ 0x00000002
#define HT_CTRL_LA_MAI 0x0000003C
#define HT_CTRL_LA_MAI_SHIFT 2
#define HT_CTRL_LA_MAI_MRQ 0x00000004
#define HT_CTRL_LA_MAI_MSI 0x00000038
#define HT_CTRL_LA_MFSI 0x000001C0
#define HT_CTRL_LA_MFSI_SHIFT 6
#define HT_CTRL_LA_MFB_ASELC 0x0000FE00
#define HT_CTRL_LA_MFB_ASELC_SH 9
#define HT_CTRL_LA_ASELC_CMD 0x00000C00
#define HT_CTRL_LA_ASELC_DATA 0x0000F000
#define HT_CTRL_CAL_POS 0x00030000
#define HT_CTRL_CAL_SEQ 0x000C0000
#define HT_CTRL_CSI_STEERING 0x00C00000
#define HT_CTRL_CSI_STEER_SHIFT 22
#define HT_CTRL_CSI_STEER_NFB 0
#define HT_CTRL_CSI_STEER_CSI 1
#define HT_CTRL_CSI_STEER_NCOM 2
#define HT_CTRL_CSI_STEER_COM 3
#define HT_CTRL_NDP_ANNOUNCE 0x01000000
#define HT_CTRL_AC_CONSTRAINT 0x40000000
#define HT_CTRL_RDG_MOREPPDU 0x80000000
#define HT_OPMODE_OPTIONAL 0x0001
#define HT_OPMODE_HT20IN40 0x0002
#define HT_OPMODE_MIXED 0x0003
#define HT_OPMODE_NONGF 0x0004
#define DOT11N_TXBURST 0x0008
#define DOT11N_OBSS_NONHT 0x0010
#define WPA_OUI "\x00\x50\xF2"
#define WPA_OUI_LEN 3
#define WPA_OUI_TYPE 1
#define WPA_VERSION 1
#define WPA2_OUI "\x00\x0F\xAC"
#define WPA2_OUI_LEN 3
#define WPA2_VERSION 1
#define WPA2_VERSION_LEN 2
#define WPS_OUI "\x00\x50\xF2"
#define WPS_OUI_LEN 3
#define WPS_OUI_TYPE 4
#define WFA_OUI "\x50\x6F\x9A"
#define WFA_OUI_LEN 3
#define WFA_OUI_TYPE_WPA 1
#define WFA_OUI_TYPE_WPS 4
#define WFA_OUI_TYPE_TPC 8
#define WFA_OUI_TYPE_P2P 9
#define RSN_AKM_NONE 0
#define RSN_AKM_UNSPECIFIED 1
#define RSN_AKM_PSK 2
#define RSN_AKM_FBT_1X 3
#define RSN_AKM_FBT_PSK 4
#define DOT11_MAX_DEFAULT_KEYS 4
#define DOT11_MAX_KEY_SIZE 32
#define DOT11_MAX_IV_SIZE 16
#define DOT11_EXT_IV_FLAG (1<<5)
#define DOT11_WPA_KEY_RSC_LEN 8
#define WEP1_KEY_SIZE 5
#define WEP1_KEY_HEX_SIZE 10
#define WEP128_KEY_SIZE 13
#define WEP128_KEY_HEX_SIZE 26
#define TKIP_MIC_SIZE 8
#define TKIP_EOM_SIZE 7
#define TKIP_EOM_FLAG 0x5a
#define TKIP_KEY_SIZE 32
#define TKIP_MIC_AUTH_TX 16
#define TKIP_MIC_AUTH_RX 24
#define TKIP_MIC_SUP_RX TKIP_MIC_AUTH_TX
#define TKIP_MIC_SUP_TX TKIP_MIC_AUTH_RX
#define AES_KEY_SIZE 16
#define AES_MIC_SIZE 8
#define WCN_OUI "\x00\x50\xf2"
#define WCN_TYPE 4
BWL_PRE_PACKED_STRUCT struct dot11_mdid_ie {
uint8 id;
uint8 len;
uint16 mdid;
uint8 cap;
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_mdid_ie dot11_mdid_ie_t;
#define FBT_MDID_CAP_OVERDS 0x01
#define FBT_MDID_CAP_RRP 0x02
BWL_PRE_PACKED_STRUCT struct dot11_ft_ie {
uint8 id;
uint8 len;
uint16 mic_control;
uint8 mic[16];
uint8 anonce[32];
uint8 snonce[32];
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_ft_ie dot11_ft_ie_t;
BWL_PRE_PACKED_STRUCT struct dot11_gtk_ie {
uint8 id;
uint8 len;
uint16 key_info;
uint8 key_len;
uint8 rsc[8];
uint8 data[1];
} BWL_POST_PACKED_STRUCT;
typedef struct dot11_gtk_ie dot11_gtk_ie_t;
#include <packed_section_end.h>
#endif