1*4882a593Smuzhiyun /* 2*4882a593Smuzhiyun * Fundamental types and constants relating to 802.11 3*4882a593Smuzhiyun * 4*4882a593Smuzhiyun * Copyright (C) 2020, Broadcom. 5*4882a593Smuzhiyun * 6*4882a593Smuzhiyun * Unless you and Broadcom execute a separate written software license 7*4882a593Smuzhiyun * agreement governing use of this software, this software is licensed to you 8*4882a593Smuzhiyun * under the terms of the GNU General Public License version 2 (the "GPL"), 9*4882a593Smuzhiyun * available at http://www.broadcom.com/licenses/GPLv2.php, with the 10*4882a593Smuzhiyun * following added to such license: 11*4882a593Smuzhiyun * 12*4882a593Smuzhiyun * As a special exception, the copyright holders of this software give you 13*4882a593Smuzhiyun * permission to link this software with independent modules, and to copy and 14*4882a593Smuzhiyun * distribute the resulting executable under terms of your choice, provided that 15*4882a593Smuzhiyun * you also meet, for each linked independent module, the terms and conditions of 16*4882a593Smuzhiyun * the license of that module. An independent module is a module which is not 17*4882a593Smuzhiyun * derived from this software. The special exception does not apply to any 18*4882a593Smuzhiyun * modifications of the software. 19*4882a593Smuzhiyun * 20*4882a593Smuzhiyun * 21*4882a593Smuzhiyun * <<Broadcom-WL-IPTag/Dual:>> 22*4882a593Smuzhiyun */ 23*4882a593Smuzhiyun 24*4882a593Smuzhiyun #ifndef _802_11_H_ 25*4882a593Smuzhiyun #define _802_11_H_ 26*4882a593Smuzhiyun 27*4882a593Smuzhiyun #ifndef _TYPEDEFS_H_ 28*4882a593Smuzhiyun #include <typedefs.h> 29*4882a593Smuzhiyun #endif 30*4882a593Smuzhiyun 31*4882a593Smuzhiyun #ifndef _NET_ETHERNET_H_ 32*4882a593Smuzhiyun #include <ethernet.h> 33*4882a593Smuzhiyun #endif 34*4882a593Smuzhiyun 35*4882a593Smuzhiyun /* Include WPA definitions here for compatibility */ 36*4882a593Smuzhiyun #include <wpa.h> 37*4882a593Smuzhiyun 38*4882a593Smuzhiyun /* This marks the start of a packed structure section. */ 39*4882a593Smuzhiyun #include <packed_section_start.h> 40*4882a593Smuzhiyun 41*4882a593Smuzhiyun #define DOT11_TU_TO_US 1024 /* 802.11 Time Unit is 1024 microseconds */ 42*4882a593Smuzhiyun #define DOT11_SEC_TO_TU 977u /* 1000000 / DOT11_TU_TO_US = ~977 TU */ 43*4882a593Smuzhiyun 44*4882a593Smuzhiyun /* Generic 802.11 frame constants */ 45*4882a593Smuzhiyun #define DOT11_A3_HDR_LEN 24 /* d11 header length with A3 */ 46*4882a593Smuzhiyun #define DOT11_A4_HDR_LEN 30 /* d11 header length with A4 */ 47*4882a593Smuzhiyun #define DOT11_MAC_HDR_LEN DOT11_A3_HDR_LEN /* MAC header length */ 48*4882a593Smuzhiyun #define DOT11_FCS_LEN 4u /* d11 FCS length */ 49*4882a593Smuzhiyun #define DOT11_ICV_LEN 4 /* d11 ICV length */ 50*4882a593Smuzhiyun #define DOT11_ICV_AES_LEN 8 /* d11 ICV/AES length */ 51*4882a593Smuzhiyun #define DOT11_MAX_ICV_AES_LEN 16 /* d11 MAX ICV/AES length */ 52*4882a593Smuzhiyun #define DOT11_QOS_LEN 2 /* d11 QoS length */ 53*4882a593Smuzhiyun #define DOT11_HTC_LEN 4 /* d11 HT Control field length */ 54*4882a593Smuzhiyun 55*4882a593Smuzhiyun #define DOT11_KEY_INDEX_SHIFT 6 /* d11 key index shift */ 56*4882a593Smuzhiyun #define DOT11_IV_LEN 4 /* d11 IV length */ 57*4882a593Smuzhiyun #define DOT11_IV_TKIP_LEN 8 /* d11 IV TKIP length */ 58*4882a593Smuzhiyun #define DOT11_IV_AES_OCB_LEN 4 /* d11 IV/AES/OCB length */ 59*4882a593Smuzhiyun #define DOT11_IV_AES_CCM_LEN 8 /* d11 IV/AES/CCM length */ 60*4882a593Smuzhiyun #define DOT11_IV_WAPI_LEN 18 /* d11 IV WAPI length */ 61*4882a593Smuzhiyun /* TODO: Need to change DOT11_IV_MAX_LEN to 18, but currently unable to change as the old 62*4882a593Smuzhiyun * branches are still referencing to this component. 63*4882a593Smuzhiyun */ 64*4882a593Smuzhiyun #define DOT11_IV_MAX_LEN 8 /* maximum iv len for any encryption */ 65*4882a593Smuzhiyun 66*4882a593Smuzhiyun /* Includes MIC */ 67*4882a593Smuzhiyun #define DOT11_MAX_MPDU_BODY_LEN 2304 /* max MPDU body length */ 68*4882a593Smuzhiyun /* A4 header + QoS + CCMP + PDU + ICV + FCS = 2352 */ 69*4882a593Smuzhiyun #define DOT11_MAX_MPDU_LEN (DOT11_A4_HDR_LEN + \ 70*4882a593Smuzhiyun DOT11_QOS_LEN + \ 71*4882a593Smuzhiyun DOT11_IV_AES_CCM_LEN + \ 72*4882a593Smuzhiyun DOT11_MAX_MPDU_BODY_LEN + \ 73*4882a593Smuzhiyun DOT11_ICV_LEN + \ 74*4882a593Smuzhiyun DOT11_FCS_LEN) /* d11 max MPDU length */ 75*4882a593Smuzhiyun 76*4882a593Smuzhiyun #define DOT11_MAX_SSID_LEN 32 /* d11 max ssid length */ 77*4882a593Smuzhiyun 78*4882a593Smuzhiyun /* dot11RTSThreshold */ 79*4882a593Smuzhiyun #define DOT11_DEFAULT_RTS_LEN 2347 /* d11 default RTS length */ 80*4882a593Smuzhiyun #define DOT11_MAX_RTS_LEN 2347 /* d11 max RTS length */ 81*4882a593Smuzhiyun 82*4882a593Smuzhiyun /* dot11FragmentationThreshold */ 83*4882a593Smuzhiyun #define DOT11_MIN_FRAG_LEN 256 /* d11 min fragmentation length */ 84*4882a593Smuzhiyun #define DOT11_MAX_FRAG_LEN 2346 /* Max frag is also limited by aMPDUMaxLength 85*4882a593Smuzhiyun * of the attached PHY 86*4882a593Smuzhiyun */ 87*4882a593Smuzhiyun #define DOT11_DEFAULT_FRAG_LEN 2346 /* d11 default fragmentation length */ 88*4882a593Smuzhiyun 89*4882a593Smuzhiyun /* dot11BeaconPeriod */ 90*4882a593Smuzhiyun #define DOT11_MIN_BEACON_PERIOD 1 /* d11 min beacon period */ 91*4882a593Smuzhiyun #define DOT11_MAX_BEACON_PERIOD 0xFFFF /* d11 max beacon period */ 92*4882a593Smuzhiyun 93*4882a593Smuzhiyun /* dot11DTIMPeriod */ 94*4882a593Smuzhiyun #define DOT11_MIN_DTIM_PERIOD 1 /* d11 min DTIM period */ 95*4882a593Smuzhiyun #define DOT11_MAX_DTIM_PERIOD 0xFF /* d11 max DTIM period */ 96*4882a593Smuzhiyun 97*4882a593Smuzhiyun /** 802.2 LLC/SNAP header used by 802.11 per 802.1H */ 98*4882a593Smuzhiyun #define DOT11_LLC_SNAP_HDR_LEN 8 /* d11 LLC/SNAP header length */ 99*4882a593Smuzhiyun /* minimum LLC header length; DSAP, SSAP, 8 bit Control (unnumbered) */ 100*4882a593Smuzhiyun #define DOT11_LLC_HDR_LEN_MIN 3 101*4882a593Smuzhiyun #define DOT11_OUI_LEN 3 /* d11 OUI length */ 102*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_llc_snap_header { 103*4882a593Smuzhiyun uint8 dsap; /* always 0xAA */ 104*4882a593Smuzhiyun uint8 ssap; /* always 0xAA */ 105*4882a593Smuzhiyun uint8 ctl; /* always 0x03 */ 106*4882a593Smuzhiyun uint8 oui[DOT11_OUI_LEN]; /* RFC1042: 0x00 0x00 0x00 107*4882a593Smuzhiyun * Bridge-Tunnel: 0x00 0x00 0xF8 108*4882a593Smuzhiyun */ 109*4882a593Smuzhiyun uint16 type; /* ethertype */ 110*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 111*4882a593Smuzhiyun 112*4882a593Smuzhiyun /* RFC1042 header used by 802.11 per 802.1H */ 113*4882a593Smuzhiyun #define RFC1042_HDR_LEN (ETHER_HDR_LEN + DOT11_LLC_SNAP_HDR_LEN) /* RCF1042 header length */ 114*4882a593Smuzhiyun 115*4882a593Smuzhiyun #define SFH_LLC_SNAP_SZ (RFC1042_HDR_LEN) 116*4882a593Smuzhiyun 117*4882a593Smuzhiyun #define COPY_SFH_LLCSNAP(dst, src) \ 118*4882a593Smuzhiyun do { \ 119*4882a593Smuzhiyun *((uint32 *)dst + 0) = *((uint32 *)src + 0); \ 120*4882a593Smuzhiyun *((uint32 *)dst + 1) = *((uint32 *)src + 1); \ 121*4882a593Smuzhiyun *((uint32 *)dst + 2) = *((uint32 *)src + 2); \ 122*4882a593Smuzhiyun *((uint32 *)dst + 3) = *((uint32 *)src + 3); \ 123*4882a593Smuzhiyun *((uint32 *)dst + 4) = *((uint32 *)src + 4); \ 124*4882a593Smuzhiyun *(uint16 *)((uint32 *)dst + 5) = *(uint16 *)((uint32 *)src + 5); \ 125*4882a593Smuzhiyun } while (0) 126*4882a593Smuzhiyun 127*4882a593Smuzhiyun /* Generic 802.11 MAC header */ 128*4882a593Smuzhiyun /** 129*4882a593Smuzhiyun * N.B.: This struct reflects the full 4 address 802.11 MAC header. 130*4882a593Smuzhiyun * The fields are defined such that the shorter 1, 2, and 3 131*4882a593Smuzhiyun * address headers just use the first k fields. 132*4882a593Smuzhiyun */ 133*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_header { 134*4882a593Smuzhiyun uint16 fc; /* frame control */ 135*4882a593Smuzhiyun uint16 durid; /* duration/ID */ 136*4882a593Smuzhiyun struct ether_addr a1; /* address 1 */ 137*4882a593Smuzhiyun struct ether_addr a2; /* address 2 */ 138*4882a593Smuzhiyun struct ether_addr a3; /* address 3 */ 139*4882a593Smuzhiyun uint16 seq; /* sequence control */ 140*4882a593Smuzhiyun struct ether_addr a4; /* address 4 */ 141*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 142*4882a593Smuzhiyun 143*4882a593Smuzhiyun /* Control frames */ 144*4882a593Smuzhiyun 145*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rts_frame { 146*4882a593Smuzhiyun uint16 fc; /* frame control */ 147*4882a593Smuzhiyun uint16 durid; /* duration/ID */ 148*4882a593Smuzhiyun struct ether_addr ra; /* receiver address */ 149*4882a593Smuzhiyun struct ether_addr ta; /* transmitter address */ 150*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 151*4882a593Smuzhiyun #define DOT11_RTS_LEN 16 /* d11 RTS frame length */ 152*4882a593Smuzhiyun 153*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_cts_frame { 154*4882a593Smuzhiyun uint16 fc; /* frame control */ 155*4882a593Smuzhiyun uint16 durid; /* duration/ID */ 156*4882a593Smuzhiyun struct ether_addr ra; /* receiver address */ 157*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 158*4882a593Smuzhiyun #define DOT11_CTS_LEN 10u /* d11 CTS frame length */ 159*4882a593Smuzhiyun 160*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ack_frame { 161*4882a593Smuzhiyun uint16 fc; /* frame control */ 162*4882a593Smuzhiyun uint16 durid; /* duration/ID */ 163*4882a593Smuzhiyun struct ether_addr ra; /* receiver address */ 164*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 165*4882a593Smuzhiyun #define DOT11_ACK_LEN 10 /* d11 ACK frame length */ 166*4882a593Smuzhiyun 167*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ps_poll_frame { 168*4882a593Smuzhiyun uint16 fc; /* frame control */ 169*4882a593Smuzhiyun uint16 durid; /* AID */ 170*4882a593Smuzhiyun struct ether_addr bssid; /* receiver address, STA in AP */ 171*4882a593Smuzhiyun struct ether_addr ta; /* transmitter address */ 172*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 173*4882a593Smuzhiyun #define DOT11_PS_POLL_LEN 16 /* d11 PS poll frame length */ 174*4882a593Smuzhiyun 175*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_cf_end_frame { 176*4882a593Smuzhiyun uint16 fc; /* frame control */ 177*4882a593Smuzhiyun uint16 durid; /* duration/ID */ 178*4882a593Smuzhiyun struct ether_addr ra; /* receiver address */ 179*4882a593Smuzhiyun struct ether_addr bssid; /* transmitter address, STA in AP */ 180*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 181*4882a593Smuzhiyun #define DOT11_CS_END_LEN 16 /* d11 CF-END frame length */ 182*4882a593Smuzhiyun 183*4882a593Smuzhiyun /** 184*4882a593Smuzhiyun * RWL wifi protocol: The Vendor Specific Action frame is defined for vendor-specific signaling 185*4882a593Smuzhiyun * category+OUI+vendor specific content ( this can be variable) 186*4882a593Smuzhiyun */ 187*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_action_wifi_vendor_specific { 188*4882a593Smuzhiyun uint8 category; 189*4882a593Smuzhiyun uint8 OUI[3]; 190*4882a593Smuzhiyun uint8 type; 191*4882a593Smuzhiyun uint8 subtype; 192*4882a593Smuzhiyun uint8 data[1040]; 193*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 194*4882a593Smuzhiyun typedef struct dot11_action_wifi_vendor_specific dot11_action_wifi_vendor_specific_t; 195*4882a593Smuzhiyun 196*4882a593Smuzhiyun /** generic vendor specific action frame with variable length */ 197*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_action_vs_frmhdr { 198*4882a593Smuzhiyun uint8 category; 199*4882a593Smuzhiyun uint8 OUI[3]; 200*4882a593Smuzhiyun uint8 type; 201*4882a593Smuzhiyun uint8 subtype; 202*4882a593Smuzhiyun uint8 data[1]; 203*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 204*4882a593Smuzhiyun typedef struct dot11_action_vs_frmhdr dot11_action_vs_frmhdr_t; 205*4882a593Smuzhiyun 206*4882a593Smuzhiyun #define DOT11_ACTION_VS_HDR_LEN 6 207*4882a593Smuzhiyun 208*4882a593Smuzhiyun #define BCM_ACTION_OUI_BYTE0 0x00 209*4882a593Smuzhiyun #define BCM_ACTION_OUI_BYTE1 0x90 210*4882a593Smuzhiyun #define BCM_ACTION_OUI_BYTE2 0x4c 211*4882a593Smuzhiyun 212*4882a593Smuzhiyun /* BA/BAR Control parameters */ 213*4882a593Smuzhiyun #define DOT11_BA_CTL_POLICY_NORMAL 0x0000 /* normal ack */ 214*4882a593Smuzhiyun #define DOT11_BA_CTL_POLICY_NOACK 0x0001 /* no ack */ 215*4882a593Smuzhiyun #define DOT11_BA_CTL_POLICY_MASK 0x0001 /* ack policy mask */ 216*4882a593Smuzhiyun 217*4882a593Smuzhiyun #define DOT11_BA_CTL_MTID 0x0002 /* multi tid BA */ 218*4882a593Smuzhiyun #define DOT11_BA_CTL_COMPRESSED 0x0004 /* compressed bitmap */ 219*4882a593Smuzhiyun 220*4882a593Smuzhiyun #define DOT11_BA_CTL_NUMMSDU_MASK 0x0FC0 /* num msdu in bitmap mask */ 221*4882a593Smuzhiyun #define DOT11_BA_CTL_NUMMSDU_SHIFT 6 /* num msdu in bitmap shift */ 222*4882a593Smuzhiyun 223*4882a593Smuzhiyun #define DOT11_BA_CTL_TID_MASK 0xF000 /* tid mask */ 224*4882a593Smuzhiyun #define DOT11_BA_CTL_TID_SHIFT 12 /* tid shift */ 225*4882a593Smuzhiyun 226*4882a593Smuzhiyun /** control frame header (BA/BAR) */ 227*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ctl_header { 228*4882a593Smuzhiyun uint16 fc; /* frame control */ 229*4882a593Smuzhiyun uint16 durid; /* duration/ID */ 230*4882a593Smuzhiyun struct ether_addr ra; /* receiver address */ 231*4882a593Smuzhiyun struct ether_addr ta; /* transmitter address */ 232*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 233*4882a593Smuzhiyun #define DOT11_CTL_HDR_LEN 16 /* control frame hdr len */ 234*4882a593Smuzhiyun 235*4882a593Smuzhiyun /** BAR frame payload */ 236*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_bar { 237*4882a593Smuzhiyun uint16 bar_control; /* BAR Control */ 238*4882a593Smuzhiyun uint16 seqnum; /* Starting Sequence control */ 239*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 240*4882a593Smuzhiyun #define DOT11_BAR_LEN 4 /* BAR frame payload length */ 241*4882a593Smuzhiyun 242*4882a593Smuzhiyun #define DOT11_BA_BITMAP_LEN 128 /* bitmap length */ 243*4882a593Smuzhiyun #define DOT11_BA_CMP_BITMAP_LEN 8 /* compressed bitmap length */ 244*4882a593Smuzhiyun /** BA frame payload */ 245*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ba { 246*4882a593Smuzhiyun uint16 ba_control; /* BA Control */ 247*4882a593Smuzhiyun uint16 seqnum; /* Starting Sequence control */ 248*4882a593Smuzhiyun uint8 bitmap[DOT11_BA_BITMAP_LEN]; /* Block Ack Bitmap */ 249*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 250*4882a593Smuzhiyun #define DOT11_BA_LEN 4 /* BA frame payload len (wo bitmap) */ 251*4882a593Smuzhiyun 252*4882a593Smuzhiyun /** Management frame header */ 253*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_management_header { 254*4882a593Smuzhiyun uint16 fc; /* frame control */ 255*4882a593Smuzhiyun uint16 durid; /* duration/ID */ 256*4882a593Smuzhiyun struct ether_addr da; /* receiver address */ 257*4882a593Smuzhiyun struct ether_addr sa; /* transmitter address */ 258*4882a593Smuzhiyun struct ether_addr bssid; /* BSS ID */ 259*4882a593Smuzhiyun uint16 seq; /* sequence control */ 260*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 261*4882a593Smuzhiyun typedef struct dot11_management_header dot11_management_header_t; 262*4882a593Smuzhiyun #define DOT11_MGMT_HDR_LEN 24u /* d11 management header length */ 263*4882a593Smuzhiyun 264*4882a593Smuzhiyun /* Management frame payloads */ 265*4882a593Smuzhiyun 266*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_bcn_prb { 267*4882a593Smuzhiyun uint32 timestamp[2]; 268*4882a593Smuzhiyun uint16 beacon_interval; 269*4882a593Smuzhiyun uint16 capability; 270*4882a593Smuzhiyun uint8 ies[]; 271*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 272*4882a593Smuzhiyun #define DOT11_BCN_PRB_LEN 12 /* 802.11 beacon/probe frame fixed length */ 273*4882a593Smuzhiyun #define DOT11_BCN_PRB_FIXED_LEN 12u /* 802.11 beacon/probe frame fixed length */ 274*4882a593Smuzhiyun 275*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_auth { 276*4882a593Smuzhiyun uint16 alg; /* algorithm */ 277*4882a593Smuzhiyun uint16 seq; /* sequence control */ 278*4882a593Smuzhiyun uint16 status; /* status code */ 279*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 280*4882a593Smuzhiyun #define DOT11_AUTH_FIXED_LEN 6 /* length of auth frame without challenge IE */ 281*4882a593Smuzhiyun #define DOT11_AUTH_SEQ_STATUS_LEN 4 /* length of auth frame without challenge IE and 282*4882a593Smuzhiyun * without algorithm 283*4882a593Smuzhiyun */ 284*4882a593Smuzhiyun 285*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_assoc_req { 286*4882a593Smuzhiyun uint16 capability; /* capability information */ 287*4882a593Smuzhiyun uint16 listen; /* listen interval */ 288*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 289*4882a593Smuzhiyun #define DOT11_ASSOC_REQ_FIXED_LEN 4 /* length of assoc frame without info elts */ 290*4882a593Smuzhiyun 291*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_reassoc_req { 292*4882a593Smuzhiyun uint16 capability; /* capability information */ 293*4882a593Smuzhiyun uint16 listen; /* listen interval */ 294*4882a593Smuzhiyun struct ether_addr ap; /* Current AP address */ 295*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 296*4882a593Smuzhiyun #define DOT11_REASSOC_REQ_FIXED_LEN 10 /* length of assoc frame without info elts */ 297*4882a593Smuzhiyun 298*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_assoc_resp { 299*4882a593Smuzhiyun uint16 capability; /* capability information */ 300*4882a593Smuzhiyun uint16 status; /* status code */ 301*4882a593Smuzhiyun uint16 aid; /* association ID */ 302*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 303*4882a593Smuzhiyun #define DOT11_ASSOC_RESP_FIXED_LEN 6 /* length of assoc resp frame without info elts */ 304*4882a593Smuzhiyun 305*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_action_measure { 306*4882a593Smuzhiyun uint8 category; 307*4882a593Smuzhiyun uint8 action; 308*4882a593Smuzhiyun uint8 token; 309*4882a593Smuzhiyun uint8 data[1]; 310*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 311*4882a593Smuzhiyun #define DOT11_ACTION_MEASURE_LEN 3 /* d11 action measurement header length */ 312*4882a593Smuzhiyun 313*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_action_ht_ch_width { 314*4882a593Smuzhiyun uint8 category; 315*4882a593Smuzhiyun uint8 action; 316*4882a593Smuzhiyun uint8 ch_width; 317*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 318*4882a593Smuzhiyun 319*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_action_ht_mimops { 320*4882a593Smuzhiyun uint8 category; 321*4882a593Smuzhiyun uint8 action; 322*4882a593Smuzhiyun uint8 control; 323*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 324*4882a593Smuzhiyun 325*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_action_sa_query { 326*4882a593Smuzhiyun uint8 category; 327*4882a593Smuzhiyun uint8 action; 328*4882a593Smuzhiyun uint16 id; 329*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 330*4882a593Smuzhiyun 331*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_action_vht_oper_mode { 332*4882a593Smuzhiyun uint8 category; 333*4882a593Smuzhiyun uint8 action; 334*4882a593Smuzhiyun uint8 mode; 335*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 336*4882a593Smuzhiyun 337*4882a593Smuzhiyun /* These lengths assume 64 MU groups, as specified in 802.11ac-2013 */ 338*4882a593Smuzhiyun #define DOT11_ACTION_GID_MEMBERSHIP_LEN 8 /* bytes */ 339*4882a593Smuzhiyun #define DOT11_ACTION_GID_USER_POS_LEN 16 /* bytes */ 340*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_action_group_id { 341*4882a593Smuzhiyun uint8 category; 342*4882a593Smuzhiyun uint8 action; 343*4882a593Smuzhiyun uint8 membership_status[DOT11_ACTION_GID_MEMBERSHIP_LEN]; 344*4882a593Smuzhiyun uint8 user_position[DOT11_ACTION_GID_USER_POS_LEN]; 345*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 346*4882a593Smuzhiyun 347*4882a593Smuzhiyun #define SM_PWRSAVE_ENABLE 1 348*4882a593Smuzhiyun #define SM_PWRSAVE_MODE 2 349*4882a593Smuzhiyun 350*4882a593Smuzhiyun /* ************* 802.11h related definitions. ************* */ 351*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_power_cnst { 352*4882a593Smuzhiyun uint8 id; 353*4882a593Smuzhiyun uint8 len; 354*4882a593Smuzhiyun uint8 power; 355*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 356*4882a593Smuzhiyun typedef struct dot11_power_cnst dot11_power_cnst_t; 357*4882a593Smuzhiyun 358*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_power_cap { 359*4882a593Smuzhiyun int8 min; 360*4882a593Smuzhiyun int8 max; 361*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 362*4882a593Smuzhiyun typedef struct dot11_power_cap dot11_power_cap_t; 363*4882a593Smuzhiyun 364*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_tpc_rep { 365*4882a593Smuzhiyun uint8 id; 366*4882a593Smuzhiyun uint8 len; 367*4882a593Smuzhiyun uint8 tx_pwr; 368*4882a593Smuzhiyun uint8 margin; 369*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 370*4882a593Smuzhiyun typedef struct dot11_tpc_rep dot11_tpc_rep_t; 371*4882a593Smuzhiyun #define DOT11_MNG_IE_TPC_REPORT_SIZE (sizeof(dot11_tpc_rep_t)) 372*4882a593Smuzhiyun #define DOT11_MNG_IE_TPC_REPORT_LEN 2 /* length of IE data, not including 2 byte header */ 373*4882a593Smuzhiyun 374*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_supp_channels { 375*4882a593Smuzhiyun uint8 id; 376*4882a593Smuzhiyun uint8 len; 377*4882a593Smuzhiyun uint8 first_channel; 378*4882a593Smuzhiyun uint8 num_channels; 379*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 380*4882a593Smuzhiyun typedef struct dot11_supp_channels dot11_supp_channels_t; 381*4882a593Smuzhiyun 382*4882a593Smuzhiyun /** 383*4882a593Smuzhiyun * Extension Channel Offset IE: 802.11n-D1.0 spec. added sideband 384*4882a593Smuzhiyun * offset for 40MHz operation. The possible 3 values are: 385*4882a593Smuzhiyun * 1 = above control channel 386*4882a593Smuzhiyun * 3 = below control channel 387*4882a593Smuzhiyun * 0 = no extension channel 388*4882a593Smuzhiyun */ 389*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_extch { 390*4882a593Smuzhiyun uint8 id; /* IE ID, 62, DOT11_MNG_EXT_CHANNEL_OFFSET */ 391*4882a593Smuzhiyun uint8 len; /* IE length */ 392*4882a593Smuzhiyun uint8 extch; 393*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 394*4882a593Smuzhiyun typedef struct dot11_extch dot11_extch_ie_t; 395*4882a593Smuzhiyun 396*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_brcm_extch { 397*4882a593Smuzhiyun uint8 id; /* IE ID, 221, DOT11_MNG_PROPR_ID */ 398*4882a593Smuzhiyun uint8 len; /* IE length */ 399*4882a593Smuzhiyun uint8 oui[3]; /* Proprietary OUI, BRCM_PROP_OUI */ 400*4882a593Smuzhiyun uint8 type; /* type indicates what follows */ 401*4882a593Smuzhiyun uint8 extch; 402*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 403*4882a593Smuzhiyun typedef struct dot11_brcm_extch dot11_brcm_extch_ie_t; 404*4882a593Smuzhiyun 405*4882a593Smuzhiyun #define BRCM_EXTCH_IE_LEN 5 406*4882a593Smuzhiyun #define BRCM_EXTCH_IE_TYPE 53 /* 802.11n ID not yet assigned */ 407*4882a593Smuzhiyun #define DOT11_EXTCH_IE_LEN 1 408*4882a593Smuzhiyun #define DOT11_EXT_CH_MASK 0x03 /* extension channel mask */ 409*4882a593Smuzhiyun #define DOT11_EXT_CH_UPPER 0x01 /* ext. ch. on upper sb */ 410*4882a593Smuzhiyun #define DOT11_EXT_CH_LOWER 0x03 /* ext. ch. on lower sb */ 411*4882a593Smuzhiyun #define DOT11_EXT_CH_NONE 0x00 /* no extension ch. */ 412*4882a593Smuzhiyun 413*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_action_frmhdr { 414*4882a593Smuzhiyun uint8 category; 415*4882a593Smuzhiyun uint8 action; 416*4882a593Smuzhiyun uint8 data[1]; 417*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 418*4882a593Smuzhiyun typedef struct dot11_action_frmhdr dot11_action_frmhdr_t; 419*4882a593Smuzhiyun 420*4882a593Smuzhiyun /* Action Field length */ 421*4882a593Smuzhiyun #define DOT11_ACTION_CATEGORY_LEN 1u 422*4882a593Smuzhiyun #define DOT11_ACTION_ACTION_LEN 1u 423*4882a593Smuzhiyun #define DOT11_ACTION_DIALOG_TOKEN_LEN 1u 424*4882a593Smuzhiyun #define DOT11_ACTION_CAPABILITY_LEN 2u 425*4882a593Smuzhiyun #define DOT11_ACTION_STATUS_CODE_LEN 2u 426*4882a593Smuzhiyun #define DOT11_ACTION_REASON_CODE_LEN 2u 427*4882a593Smuzhiyun #define DOT11_ACTION_TARGET_CH_LEN 1u 428*4882a593Smuzhiyun #define DOT11_ACTION_OPER_CLASS_LEN 1u 429*4882a593Smuzhiyun 430*4882a593Smuzhiyun #define DOT11_ACTION_FRMHDR_LEN 2 431*4882a593Smuzhiyun 432*4882a593Smuzhiyun /** CSA IE data structure */ 433*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_channel_switch { 434*4882a593Smuzhiyun uint8 id; /* id DOT11_MNG_CHANNEL_SWITCH_ID */ 435*4882a593Smuzhiyun uint8 len; /* length of IE */ 436*4882a593Smuzhiyun uint8 mode; /* mode 0 or 1 */ 437*4882a593Smuzhiyun uint8 channel; /* channel switch to */ 438*4882a593Smuzhiyun uint8 count; /* number of beacons before switching */ 439*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 440*4882a593Smuzhiyun typedef struct dot11_channel_switch dot11_chan_switch_ie_t; 441*4882a593Smuzhiyun 442*4882a593Smuzhiyun #define DOT11_SWITCH_IE_LEN 3 /* length of IE data, not including 2 byte header */ 443*4882a593Smuzhiyun /* CSA mode - 802.11h-2003 $7.3.2.20 */ 444*4882a593Smuzhiyun #define DOT11_CSA_MODE_ADVISORY 0 /* no DOT11_CSA_MODE_NO_TX restriction imposed */ 445*4882a593Smuzhiyun #define DOT11_CSA_MODE_NO_TX 1 /* no transmission upon receiving CSA frame. */ 446*4882a593Smuzhiyun 447*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_action_switch_channel { 448*4882a593Smuzhiyun uint8 category; 449*4882a593Smuzhiyun uint8 action; 450*4882a593Smuzhiyun dot11_chan_switch_ie_t chan_switch_ie; /* for switch IE */ 451*4882a593Smuzhiyun dot11_brcm_extch_ie_t extch_ie; /* extension channel offset */ 452*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 453*4882a593Smuzhiyun 454*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_csa_body { 455*4882a593Smuzhiyun uint8 mode; /* mode 0 or 1 */ 456*4882a593Smuzhiyun uint8 reg; /* regulatory class */ 457*4882a593Smuzhiyun uint8 channel; /* channel switch to */ 458*4882a593Smuzhiyun uint8 count; /* number of beacons before switching */ 459*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 460*4882a593Smuzhiyun 461*4882a593Smuzhiyun /** 11n Extended Channel Switch IE data structure */ 462*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ext_csa { 463*4882a593Smuzhiyun uint8 id; /* id DOT11_MNG_EXT_CSA_ID */ 464*4882a593Smuzhiyun uint8 len; /* length of IE */ 465*4882a593Smuzhiyun struct dot11_csa_body b; /* body of the ie */ 466*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 467*4882a593Smuzhiyun typedef struct dot11_ext_csa dot11_ext_csa_ie_t; 468*4882a593Smuzhiyun #define DOT11_EXT_CSA_IE_LEN 4 /* length of extended channel switch IE body */ 469*4882a593Smuzhiyun 470*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_action_ext_csa { 471*4882a593Smuzhiyun uint8 category; 472*4882a593Smuzhiyun uint8 action; 473*4882a593Smuzhiyun dot11_ext_csa_ie_t chan_switch_ie; /* for switch IE */ 474*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 475*4882a593Smuzhiyun 476*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11y_action_ext_csa { 477*4882a593Smuzhiyun uint8 category; 478*4882a593Smuzhiyun uint8 action; 479*4882a593Smuzhiyun struct dot11_csa_body b; /* body of the ie */ 480*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 481*4882a593Smuzhiyun 482*4882a593Smuzhiyun /** Wide Bandwidth Channel Switch IE data structure */ 483*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_wide_bw_channel_switch { 484*4882a593Smuzhiyun uint8 id; /* id DOT11_MNG_WIDE_BW_CHANNEL_SWITCH_ID */ 485*4882a593Smuzhiyun uint8 len; /* length of IE */ 486*4882a593Smuzhiyun uint8 channel_width; /* new channel width */ 487*4882a593Smuzhiyun uint8 center_frequency_segment_0; /* center frequency segment 0 */ 488*4882a593Smuzhiyun uint8 center_frequency_segment_1; /* center frequency segment 1 */ 489*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 490*4882a593Smuzhiyun typedef struct dot11_wide_bw_channel_switch dot11_wide_bw_chan_switch_ie_t; 491*4882a593Smuzhiyun 492*4882a593Smuzhiyun #define DOT11_WIDE_BW_SWITCH_IE_LEN 3 /* length of IE data, not including 2 byte header */ 493*4882a593Smuzhiyun 494*4882a593Smuzhiyun /** Channel Switch Wrapper IE data structure */ 495*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_channel_switch_wrapper { 496*4882a593Smuzhiyun uint8 id; /* id DOT11_MNG_WIDE_BW_CHANNEL_SWITCH_ID */ 497*4882a593Smuzhiyun uint8 len; /* length of IE */ 498*4882a593Smuzhiyun dot11_wide_bw_chan_switch_ie_t wb_chan_switch_ie; 499*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 500*4882a593Smuzhiyun typedef struct dot11_channel_switch_wrapper dot11_chan_switch_wrapper_ie_t; 501*4882a593Smuzhiyun 502*4882a593Smuzhiyun /* Proposed wide bandwidth channel IE */ 503*4882a593Smuzhiyun typedef enum wide_bw_chan_width { 504*4882a593Smuzhiyun WIDE_BW_CHAN_WIDTH_20 = 0, 505*4882a593Smuzhiyun WIDE_BW_CHAN_WIDTH_40 = 1, 506*4882a593Smuzhiyun WIDE_BW_CHAN_WIDTH_80 = 2, 507*4882a593Smuzhiyun WIDE_BW_CHAN_WIDTH_160 = 3, 508*4882a593Smuzhiyun WIDE_BW_CHAN_WIDTH_80_80 = 4 509*4882a593Smuzhiyun } wide_bw_chan_width_t; 510*4882a593Smuzhiyun 511*4882a593Smuzhiyun /** Wide Bandwidth Channel IE data structure */ 512*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_wide_bw_channel { 513*4882a593Smuzhiyun uint8 id; /* id DOT11_MNG_WIDE_BW_CHANNEL_ID */ 514*4882a593Smuzhiyun uint8 len; /* length of IE */ 515*4882a593Smuzhiyun uint8 channel_width; /* channel width */ 516*4882a593Smuzhiyun uint8 center_frequency_segment_0; /* center frequency segment 0 */ 517*4882a593Smuzhiyun uint8 center_frequency_segment_1; /* center frequency segment 1 */ 518*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 519*4882a593Smuzhiyun typedef struct dot11_wide_bw_channel dot11_wide_bw_chan_ie_t; 520*4882a593Smuzhiyun 521*4882a593Smuzhiyun #define DOT11_WIDE_BW_IE_LEN 3 /* length of IE data, not including 2 byte header */ 522*4882a593Smuzhiyun /** VHT Transmit Power Envelope IE data structure */ 523*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_vht_transmit_power_envelope { 524*4882a593Smuzhiyun uint8 id; /* id DOT11_MNG_WIDE_BW_CHANNEL_SWITCH_ID */ 525*4882a593Smuzhiyun uint8 len; /* length of IE */ 526*4882a593Smuzhiyun uint8 transmit_power_info; 527*4882a593Smuzhiyun uint8 local_max_transmit_power_20; 528*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 529*4882a593Smuzhiyun typedef struct dot11_vht_transmit_power_envelope dot11_vht_transmit_power_envelope_ie_t; 530*4882a593Smuzhiyun 531*4882a593Smuzhiyun /* vht transmit power envelope IE length depends on channel width */ 532*4882a593Smuzhiyun #define DOT11_VHT_TRANSMIT_PWR_ENVELOPE_IE_LEN_40MHZ 1 533*4882a593Smuzhiyun #define DOT11_VHT_TRANSMIT_PWR_ENVELOPE_IE_LEN_80MHZ 2 534*4882a593Smuzhiyun #define DOT11_VHT_TRANSMIT_PWR_ENVELOPE_IE_LEN_160MHZ 3 535*4882a593Smuzhiyun 536*4882a593Smuzhiyun /* TPE Transmit Power Information Field */ 537*4882a593Smuzhiyun #define DOT11_TPE_INFO_MAX_TX_PWR_CNT_MASK 0x07u 538*4882a593Smuzhiyun #define DOT11_TPE_INFO_MAX_TX_PWR_INTRPN_MASK 0x38u 539*4882a593Smuzhiyun #define DOT11_TPE_INFO_MAX_TX_PWR_INTRPN_SHIFT 3u 540*4882a593Smuzhiyun #define DOT11_TPE_INFO_MAX_TX_PWR_CAT_MASK 0xC0u 541*4882a593Smuzhiyun #define DOT11_TPE_INFO_MAX_TX_PWR_CAT_SHIFT 6u 542*4882a593Smuzhiyun 543*4882a593Smuzhiyun /* TPE Transmit Power Information Field Accessor */ 544*4882a593Smuzhiyun #define DOT11_TPE_INFO_MAX_TX_PWR_CNT(x) \ 545*4882a593Smuzhiyun (x & DOT11_TPE_INFO_MAX_TX_PWR_CNT_MASK) 546*4882a593Smuzhiyun #define DOT11_TPE_INFO_MAX_TX_PWR_INTRPN(x) \ 547*4882a593Smuzhiyun (((x) & DOT11_TPE_INFO_MAX_TX_PWR_INTRPN_MASK) >> \ 548*4882a593Smuzhiyun DOT11_TPE_INFO_MAX_TX_PWR_INTRPN_SHIFT) 549*4882a593Smuzhiyun #define DOT11_TPE_INFO_MAX_TX_PWR_CAT(x) \ 550*4882a593Smuzhiyun (((x) & DOT11_TPE_INFO_MAX_TX_PWR_CAT_MASK) >> \ 551*4882a593Smuzhiyun DOT11_TPE_INFO_MAX_TX_PWR_CAT_SHIFT) 552*4882a593Smuzhiyun 553*4882a593Smuzhiyun /* Maximum Transmit Power Interpretation subfield */ 554*4882a593Smuzhiyun #define DOT11_TPE_MAX_TX_PWR_INTRPN_LOCAL_EIRP 0u 555*4882a593Smuzhiyun #define DOT11_TPE_MAX_TX_PWR_INTRPN_LOCAL_EIRP_PSD 1u 556*4882a593Smuzhiyun #define DOT11_TPE_MAX_TX_PWR_INTRPN_REG_CLIENT_EIRP 2u 557*4882a593Smuzhiyun #define DOT11_TPE_MAX_TX_PWR_INTRPN_REG_CLIENT_EIRP_PSD 3u 558*4882a593Smuzhiyun 559*4882a593Smuzhiyun /* Maximum Transmit Power category subfield */ 560*4882a593Smuzhiyun #define DOT11_TPE_MAX_TX_PWR_CAT_DEFAULT 0u 561*4882a593Smuzhiyun 562*4882a593Smuzhiyun /* Maximum Transmit Power category subfield in US */ 563*4882a593Smuzhiyun #define DOT11_TPE_MAX_TX_PWR_CAT_US_DEFAULT 0u 564*4882a593Smuzhiyun #define DOT11_TPE_MAX_TX_PWR_CAT_US_SUB_DEV 1u 565*4882a593Smuzhiyun 566*4882a593Smuzhiyun /* Maximum Transmit Power Count subfield values when 567*4882a593Smuzhiyun * Maximum Transmit Power Interpretation subfield is 0 or 2 568*4882a593Smuzhiyun */ 569*4882a593Smuzhiyun #define DOT11_TPE_INFO_MAX_TX_CNT_EIRP_20_MHZ 0u 570*4882a593Smuzhiyun #define DOT11_TPE_INFO_MAX_TX_CNT_EIRP_20_40_MHZ 1u 571*4882a593Smuzhiyun #define DOT11_TPE_INFO_MAX_TX_CNT_EIRP_20_40_80_MHZ 2u 572*4882a593Smuzhiyun #define DOT11_TPE_INFO_MAX_TX_CNT_EIRP_20_40_80_160_MHZ 3u 573*4882a593Smuzhiyun 574*4882a593Smuzhiyun /* Maximum Transmit Power Count subfield values when 575*4882a593Smuzhiyun * Maximum Transmit Power Interpretation subfield is 1 or 3 576*4882a593Smuzhiyun */ 577*4882a593Smuzhiyun #define DOT11_TPE_INFO_MAX_TX_CNT_PSD_VAL_0 0u 578*4882a593Smuzhiyun #define DOT11_TPE_INFO_MAX_TX_CNT_PSD_VAL_1 1u 579*4882a593Smuzhiyun #define DOT11_TPE_INFO_MAX_TX_CNT_PSD_VAL_2 2u 580*4882a593Smuzhiyun #define DOT11_TPE_INFO_MAX_TX_CNT_PSD_VAL_3 4u 581*4882a593Smuzhiyun #define DOT11_TPE_INFO_MAX_TX_CNT_PSD_VAL_4 8u 582*4882a593Smuzhiyun 583*4882a593Smuzhiyun #define DOT11_TPE_MAX_TX_PWR_EIRP_MIN -128 /* 0.5 db step */ 584*4882a593Smuzhiyun #define DOT11_TPE_MAX_TX_PWR_EIRP_MAX 126 /* 0.5 db step */ 585*4882a593Smuzhiyun #define DOT11_TPE_MAX_TX_PWR_EIRP_NO_LIMIT 127 /* 0.5 db step */ 586*4882a593Smuzhiyun 587*4882a593Smuzhiyun #define DOT11_TPE_MAX_TX_PWR_PSD_BLOCKED -128 588*4882a593Smuzhiyun #define DOT11_TPE_MAX_TX_PWR_PSD_NO_LIMIT 127u 589*4882a593Smuzhiyun /** Transmit Power Envelope IE data structure as per 11ax draft */ 590*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_transmit_power_envelope { 591*4882a593Smuzhiyun uint8 id; /* id DOT11_MNG_WIDE_BW_CHANNEL_SWITCH_ID */ 592*4882a593Smuzhiyun uint8 len; /* length of IE */ 593*4882a593Smuzhiyun uint8 transmit_power_info; 594*4882a593Smuzhiyun uint8 max_transmit_power[]; /* Variable length */ 595*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 596*4882a593Smuzhiyun typedef struct dot11_transmit_power_envelope dot11_transmit_power_envelope_ie_t; 597*4882a593Smuzhiyun /* id (1) + len (1) + transmit_power_info(1) + max_transmit_power(1) */ 598*4882a593Smuzhiyun #define DOT11_TPE_ELEM_MIN_LEN 4u 599*4882a593Smuzhiyun 600*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_obss_coex { 601*4882a593Smuzhiyun uint8 id; 602*4882a593Smuzhiyun uint8 len; 603*4882a593Smuzhiyun uint8 info; 604*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 605*4882a593Smuzhiyun typedef struct dot11_obss_coex dot11_obss_coex_t; 606*4882a593Smuzhiyun #define DOT11_OBSS_COEXINFO_LEN 1 /* length of OBSS Coexistence INFO IE */ 607*4882a593Smuzhiyun 608*4882a593Smuzhiyun #define DOT11_OBSS_COEX_INFO_REQ 0x01 609*4882a593Smuzhiyun #define DOT11_OBSS_COEX_40MHZ_INTOLERANT 0x02 610*4882a593Smuzhiyun #define DOT11_OBSS_COEX_20MHZ_WIDTH_REQ 0x04 611*4882a593Smuzhiyun 612*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_obss_chanlist { 613*4882a593Smuzhiyun uint8 id; 614*4882a593Smuzhiyun uint8 len; 615*4882a593Smuzhiyun uint8 regclass; 616*4882a593Smuzhiyun uint8 chanlist[1]; 617*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 618*4882a593Smuzhiyun typedef struct dot11_obss_chanlist dot11_obss_chanlist_t; 619*4882a593Smuzhiyun #define DOT11_OBSS_CHANLIST_FIXED_LEN 1 /* fixed length of regclass */ 620*4882a593Smuzhiyun 621*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_extcap_ie { 622*4882a593Smuzhiyun uint8 id; 623*4882a593Smuzhiyun uint8 len; 624*4882a593Smuzhiyun uint8 cap[1]; 625*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 626*4882a593Smuzhiyun typedef struct dot11_extcap_ie dot11_extcap_ie_t; 627*4882a593Smuzhiyun 628*4882a593Smuzhiyun #define DOT11_EXTCAP_LEN_COEX 1 629*4882a593Smuzhiyun #define DOT11_EXTCAP_LEN_BT 3 630*4882a593Smuzhiyun #define DOT11_EXTCAP_LEN_IW 4 631*4882a593Smuzhiyun #define DOT11_EXTCAP_LEN_SI 6 632*4882a593Smuzhiyun 633*4882a593Smuzhiyun #define DOT11_EXTCAP_LEN_TDLS 5 634*4882a593Smuzhiyun #define DOT11_11AC_EXTCAP_LEN_TDLS 8 635*4882a593Smuzhiyun 636*4882a593Smuzhiyun #define DOT11_EXTCAP_LEN_FMS 2 637*4882a593Smuzhiyun #define DOT11_EXTCAP_LEN_PROXY_ARP 2 638*4882a593Smuzhiyun #define DOT11_EXTCAP_LEN_TFS 3 639*4882a593Smuzhiyun #define DOT11_EXTCAP_LEN_WNM_SLEEP 3 640*4882a593Smuzhiyun #define DOT11_EXTCAP_LEN_TIMBC 3 641*4882a593Smuzhiyun #define DOT11_EXTCAP_LEN_BSSTRANS 3 642*4882a593Smuzhiyun #define DOT11_EXTCAP_LEN_DMS 4 643*4882a593Smuzhiyun #define DOT11_EXTCAP_LEN_WNM_NOTIFICATION 6 644*4882a593Smuzhiyun #define DOT11_EXTCAP_LEN_TDLS_WBW 8 645*4882a593Smuzhiyun #define DOT11_EXTCAP_LEN_OPMODE_NOTIFICATION 8 646*4882a593Smuzhiyun #define DOT11_EXTCAP_LEN_TWT 10u 647*4882a593Smuzhiyun #define DOT11_EXTCAP_LEN_BCN_PROT 11u 648*4882a593Smuzhiyun 649*4882a593Smuzhiyun /* TDLS Capabilities */ 650*4882a593Smuzhiyun #define DOT11_TDLS_CAP_TDLS 37 /* TDLS support */ 651*4882a593Smuzhiyun #define DOT11_TDLS_CAP_PU_BUFFER_STA 28 /* TDLS Peer U-APSD buffer STA support */ 652*4882a593Smuzhiyun #define DOT11_TDLS_CAP_PEER_PSM 20 /* TDLS Peer PSM support */ 653*4882a593Smuzhiyun #define DOT11_TDLS_CAP_CH_SW 30 /* TDLS Channel switch */ 654*4882a593Smuzhiyun #define DOT11_TDLS_CAP_PROH 38 /* TDLS prohibited */ 655*4882a593Smuzhiyun #define DOT11_TDLS_CAP_CH_SW_PROH 39 /* TDLS Channel switch prohibited */ 656*4882a593Smuzhiyun #define DOT11_TDLS_CAP_TDLS_WIDER_BW 61 /* TDLS Wider Band-Width */ 657*4882a593Smuzhiyun 658*4882a593Smuzhiyun #define TDLS_CAP_MAX_BIT 39 /* TDLS max bit defined in ext cap */ 659*4882a593Smuzhiyun 660*4882a593Smuzhiyun /* FIXME: remove redundant DOT11_CAP_SAE_HASH_TO_ELEMENT */ 661*4882a593Smuzhiyun #define DOT11_CAP_SAE_HASH_TO_ELEMENT 5u /* SAE Hash-to-element support */ 662*4882a593Smuzhiyun #define DOT11_EXT_RSN_CAP_SAE_H2E 5u /* SAE Hash-to-element support */ 663*4882a593Smuzhiyun /* FIXME: Use these temporary IDs until ANA assigns IDs */ 664*4882a593Smuzhiyun #define DOT11_EXT_RSN_CAP_SAE_PK 6u /* SAE-PK support */ 665*4882a593Smuzhiyun /* Last bit in extended rsn capabilities (RSNXE) */ 666*4882a593Smuzhiyun #define DOT11_EXT_RSN_CAP_MAX_BIT DOT11_EXT_RSN_CAP_SAE_PK 667*4882a593Smuzhiyun 668*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rsnxe { 669*4882a593Smuzhiyun uint8 id; /* id DOT11_MNG_RSNXE_ID */ 670*4882a593Smuzhiyun uint8 len; 671*4882a593Smuzhiyun uint8 cap[1]; 672*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 673*4882a593Smuzhiyun typedef struct dot11_rsnxe dot11_rsnxe_t; 674*4882a593Smuzhiyun 675*4882a593Smuzhiyun #define RSNXE_CAP_LENGTH_MASK (0x0f) 676*4882a593Smuzhiyun #define RSNXE_CAP_LENGTH(cap) ((uint8)(cap) & RSNXE_CAP_LENGTH_MASK) 677*4882a593Smuzhiyun #define RSNXE_SET_CAP_LENGTH(cap, len)\ 678*4882a593Smuzhiyun (cap = (cap & ~RSNXE_CAP_LENGTH_MASK) | ((uint8)(len) & RSNXE_CAP_LENGTH_MASK)) 679*4882a593Smuzhiyun 680*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rejected_groups_ie { 681*4882a593Smuzhiyun uint8 id; /* DOT11_MNG_EXT_ID */ 682*4882a593Smuzhiyun uint8 len; 683*4882a593Smuzhiyun uint8 id_ext; /* DOT11_MNG_REJECTED_GROUPS_ID */ 684*4882a593Smuzhiyun uint16 groups[]; 685*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 686*4882a593Smuzhiyun typedef struct dot11_rejected_groups_ie dot11_rejected_groups_ie_t; 687*4882a593Smuzhiyun 688*4882a593Smuzhiyun /* 802.11h/802.11k Measurement Request/Report IEs */ 689*4882a593Smuzhiyun /* Measurement Type field */ 690*4882a593Smuzhiyun #define DOT11_MEASURE_TYPE_BASIC 0 /* d11 measurement basic type */ 691*4882a593Smuzhiyun #define DOT11_MEASURE_TYPE_CCA 1 /* d11 measurement CCA type */ 692*4882a593Smuzhiyun #define DOT11_MEASURE_TYPE_RPI 2 /* d11 measurement RPI type */ 693*4882a593Smuzhiyun #define DOT11_MEASURE_TYPE_CHLOAD 3 /* d11 measurement Channel Load type */ 694*4882a593Smuzhiyun #define DOT11_MEASURE_TYPE_NOISE 4 /* d11 measurement Noise Histogram type */ 695*4882a593Smuzhiyun #define DOT11_MEASURE_TYPE_BEACON 5 /* d11 measurement Beacon type */ 696*4882a593Smuzhiyun #define DOT11_MEASURE_TYPE_FRAME 6 /* d11 measurement Frame type */ 697*4882a593Smuzhiyun #define DOT11_MEASURE_TYPE_STAT 7 /* d11 measurement STA Statistics type */ 698*4882a593Smuzhiyun #define DOT11_MEASURE_TYPE_LCI 8 /* d11 measurement LCI type */ 699*4882a593Smuzhiyun #define DOT11_MEASURE_TYPE_TXSTREAM 9 /* d11 measurement TX Stream type */ 700*4882a593Smuzhiyun #define DOT11_MEASURE_TYPE_MCDIAGS 10 /* d11 measurement multicast diagnostics */ 701*4882a593Smuzhiyun #define DOT11_MEASURE_TYPE_CIVICLOC 11 /* d11 measurement location civic */ 702*4882a593Smuzhiyun #define DOT11_MEASURE_TYPE_LOC_ID 12 /* d11 measurement location identifier */ 703*4882a593Smuzhiyun #define DOT11_MEASURE_TYPE_DIRCHANQ 13 /* d11 measurement dir channel quality */ 704*4882a593Smuzhiyun #define DOT11_MEASURE_TYPE_DIRMEAS 14 /* d11 measurement directional */ 705*4882a593Smuzhiyun #define DOT11_MEASURE_TYPE_DIRSTATS 15 /* d11 measurement directional stats */ 706*4882a593Smuzhiyun #define DOT11_MEASURE_TYPE_FTMRANGE 16 /* d11 measurement Fine Timing */ 707*4882a593Smuzhiyun #define DOT11_MEASURE_TYPE_PAUSE 255 /* d11 measurement pause type */ 708*4882a593Smuzhiyun 709*4882a593Smuzhiyun /* Measurement Request Modes */ 710*4882a593Smuzhiyun #define DOT11_MEASURE_MODE_PARALLEL (1<<0) /* d11 measurement parallel */ 711*4882a593Smuzhiyun #define DOT11_MEASURE_MODE_ENABLE (1<<1) /* d11 measurement enable */ 712*4882a593Smuzhiyun #define DOT11_MEASURE_MODE_REQUEST (1<<2) /* d11 measurement request */ 713*4882a593Smuzhiyun #define DOT11_MEASURE_MODE_REPORT (1<<3) /* d11 measurement report */ 714*4882a593Smuzhiyun #define DOT11_MEASURE_MODE_DUR (1<<4) /* d11 measurement dur mandatory */ 715*4882a593Smuzhiyun /* Measurement Report Modes */ 716*4882a593Smuzhiyun #define DOT11_MEASURE_MODE_LATE (1<<0) /* d11 measurement late */ 717*4882a593Smuzhiyun #define DOT11_MEASURE_MODE_INCAPABLE (1<<1) /* d11 measurement incapable */ 718*4882a593Smuzhiyun #define DOT11_MEASURE_MODE_REFUSED (1<<2) /* d11 measurement refuse */ 719*4882a593Smuzhiyun /* Basic Measurement Map bits */ 720*4882a593Smuzhiyun #define DOT11_MEASURE_BASIC_MAP_BSS ((uint8)(1<<0)) /* d11 measurement basic map BSS */ 721*4882a593Smuzhiyun #define DOT11_MEASURE_BASIC_MAP_OFDM ((uint8)(1<<1)) /* d11 measurement map OFDM */ 722*4882a593Smuzhiyun #define DOT11_MEASURE_BASIC_MAP_UKNOWN ((uint8)(1<<2)) /* d11 measurement map unknown */ 723*4882a593Smuzhiyun #define DOT11_MEASURE_BASIC_MAP_RADAR ((uint8)(1<<3)) /* d11 measurement map radar */ 724*4882a593Smuzhiyun #define DOT11_MEASURE_BASIC_MAP_UNMEAS ((uint8)(1<<4)) /* d11 measurement map unmeasuremnt */ 725*4882a593Smuzhiyun 726*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_meas_req { 727*4882a593Smuzhiyun uint8 id; 728*4882a593Smuzhiyun uint8 len; 729*4882a593Smuzhiyun uint8 token; 730*4882a593Smuzhiyun uint8 mode; 731*4882a593Smuzhiyun uint8 type; 732*4882a593Smuzhiyun uint8 channel; 733*4882a593Smuzhiyun uint8 start_time[8]; 734*4882a593Smuzhiyun uint16 duration; 735*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 736*4882a593Smuzhiyun typedef struct dot11_meas_req dot11_meas_req_t; 737*4882a593Smuzhiyun #define DOT11_MNG_IE_MREQ_LEN 14 /* d11 measurement request IE length */ 738*4882a593Smuzhiyun /* length of Measure Request IE data not including variable len */ 739*4882a593Smuzhiyun #define DOT11_MNG_IE_MREQ_FIXED_LEN 3 /* d11 measurement request IE fixed length */ 740*4882a593Smuzhiyun 741*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_meas_req_loc { 742*4882a593Smuzhiyun uint8 id; 743*4882a593Smuzhiyun uint8 len; 744*4882a593Smuzhiyun uint8 token; 745*4882a593Smuzhiyun uint8 mode; 746*4882a593Smuzhiyun uint8 type; 747*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT union 748*4882a593Smuzhiyun { 749*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct { 750*4882a593Smuzhiyun uint8 subject; 751*4882a593Smuzhiyun uint8 data[1]; 752*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT lci; 753*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct { 754*4882a593Smuzhiyun uint8 subject; 755*4882a593Smuzhiyun uint8 type; /* type of civic location */ 756*4882a593Smuzhiyun uint8 siu; /* service interval units */ 757*4882a593Smuzhiyun uint16 si; /* service interval */ 758*4882a593Smuzhiyun uint8 data[1]; 759*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT civic; 760*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct { 761*4882a593Smuzhiyun uint8 subject; 762*4882a593Smuzhiyun uint8 siu; /* service interval units */ 763*4882a593Smuzhiyun uint16 si; /* service interval */ 764*4882a593Smuzhiyun uint8 data[1]; 765*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT locid; 766*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct { 767*4882a593Smuzhiyun uint16 max_init_delay; /* maximum random initial delay */ 768*4882a593Smuzhiyun uint8 min_ap_count; 769*4882a593Smuzhiyun uint8 data[1]; 770*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT ftm_range; 771*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT req; 772*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 773*4882a593Smuzhiyun typedef struct dot11_meas_req_loc dot11_meas_req_loc_t; 774*4882a593Smuzhiyun #define DOT11_MNG_IE_MREQ_MIN_LEN 4 /* d11 measurement report IE length */ 775*4882a593Smuzhiyun #define DOT11_MNG_IE_MREQ_LCI_FIXED_LEN 4 /* d11 measurement report IE length */ 776*4882a593Smuzhiyun #define DOT11_MNG_IE_MREQ_CIVIC_FIXED_LEN 8 /* d11 measurement report IE length */ 777*4882a593Smuzhiyun #define DOT11_MNG_IE_MREQ_FRNG_FIXED_LEN 6 /* d11 measurement report IE length */ 778*4882a593Smuzhiyun 779*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_lci_subelement { 780*4882a593Smuzhiyun uint8 subelement; 781*4882a593Smuzhiyun uint8 length; 782*4882a593Smuzhiyun uint8 lci_data[1]; 783*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 784*4882a593Smuzhiyun typedef struct dot11_lci_subelement dot11_lci_subelement_t; 785*4882a593Smuzhiyun 786*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_colocated_bssid_list_se { 787*4882a593Smuzhiyun uint8 sub_id; 788*4882a593Smuzhiyun uint8 length; 789*4882a593Smuzhiyun uint8 max_bssid_ind; /* MaxBSSID Indicator */ 790*4882a593Smuzhiyun struct ether_addr bssid[1]; /* variable */ 791*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 792*4882a593Smuzhiyun typedef struct dot11_colocated_bssid_list_se dot11_colocated_bssid_list_se_t; 793*4882a593Smuzhiyun #define DOT11_LCI_COLOCATED_BSSID_LIST_FIXED_LEN 3 794*4882a593Smuzhiyun #define DOT11_LCI_COLOCATED_BSSID_SUBELEM_ID 7 795*4882a593Smuzhiyun 796*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_civic_subelement { 797*4882a593Smuzhiyun uint8 type; /* type of civic location */ 798*4882a593Smuzhiyun uint8 subelement; 799*4882a593Smuzhiyun uint8 length; 800*4882a593Smuzhiyun uint8 civic_data[1]; 801*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 802*4882a593Smuzhiyun typedef struct dot11_civic_subelement dot11_civic_subelement_t; 803*4882a593Smuzhiyun 804*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_meas_rep { 805*4882a593Smuzhiyun uint8 id; 806*4882a593Smuzhiyun uint8 len; 807*4882a593Smuzhiyun uint8 token; 808*4882a593Smuzhiyun uint8 mode; 809*4882a593Smuzhiyun uint8 type; 810*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT union 811*4882a593Smuzhiyun { 812*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct { 813*4882a593Smuzhiyun uint8 channel; 814*4882a593Smuzhiyun uint8 start_time[8]; 815*4882a593Smuzhiyun uint16 duration; 816*4882a593Smuzhiyun uint8 map; 817*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT basic; 818*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct { 819*4882a593Smuzhiyun uint8 subelement; 820*4882a593Smuzhiyun uint8 length; 821*4882a593Smuzhiyun uint8 data[1]; 822*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT lci; 823*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct { 824*4882a593Smuzhiyun uint8 type; /* type of civic location */ 825*4882a593Smuzhiyun uint8 subelement; 826*4882a593Smuzhiyun uint8 length; 827*4882a593Smuzhiyun uint8 data[1]; 828*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT civic; 829*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct { 830*4882a593Smuzhiyun uint8 exp_tsf[8]; 831*4882a593Smuzhiyun uint8 subelement; 832*4882a593Smuzhiyun uint8 length; 833*4882a593Smuzhiyun uint8 data[1]; 834*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT locid; 835*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct { 836*4882a593Smuzhiyun uint8 entry_count; 837*4882a593Smuzhiyun uint8 data[1]; 838*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT ftm_range; 839*4882a593Smuzhiyun uint8 data[1]; 840*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT rep; 841*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 842*4882a593Smuzhiyun typedef struct dot11_meas_rep dot11_meas_rep_t; 843*4882a593Smuzhiyun #define DOT11_MNG_IE_MREP_MIN_LEN 5 /* d11 measurement report IE length */ 844*4882a593Smuzhiyun #define DOT11_MNG_IE_MREP_LCI_FIXED_LEN 5 /* d11 measurement report IE length */ 845*4882a593Smuzhiyun #define DOT11_MNG_IE_MREP_CIVIC_FIXED_LEN 6 /* d11 measurement report IE length */ 846*4882a593Smuzhiyun #define DOT11_MNG_IE_MREP_LOCID_FIXED_LEN 13 /* d11 measurement report IE length */ 847*4882a593Smuzhiyun #define DOT11_MNG_IE_MREP_BASIC_FIXED_LEN 15 /* d11 measurement report IE length */ 848*4882a593Smuzhiyun #define DOT11_MNG_IE_MREP_FRNG_FIXED_LEN 4 849*4882a593Smuzhiyun 850*4882a593Smuzhiyun /* length of Measure Report IE data not including variable len */ 851*4882a593Smuzhiyun #define DOT11_MNG_IE_MREP_FIXED_LEN 3 /* d11 measurement response IE fixed length */ 852*4882a593Smuzhiyun 853*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_meas_rep_basic { 854*4882a593Smuzhiyun uint8 channel; 855*4882a593Smuzhiyun uint8 start_time[8]; 856*4882a593Smuzhiyun uint16 duration; 857*4882a593Smuzhiyun uint8 map; 858*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 859*4882a593Smuzhiyun typedef struct dot11_meas_rep_basic dot11_meas_rep_basic_t; 860*4882a593Smuzhiyun #define DOT11_MEASURE_BASIC_REP_LEN 12 /* d11 measurement basic report length */ 861*4882a593Smuzhiyun 862*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_quiet { 863*4882a593Smuzhiyun uint8 id; 864*4882a593Smuzhiyun uint8 len; 865*4882a593Smuzhiyun uint8 count; /* TBTTs until beacon interval in quiet starts */ 866*4882a593Smuzhiyun uint8 period; /* Beacon intervals between periodic quiet periods ? */ 867*4882a593Smuzhiyun uint16 duration; /* Length of quiet period, in TU's */ 868*4882a593Smuzhiyun uint16 offset; /* TU's offset from TBTT in Count field */ 869*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 870*4882a593Smuzhiyun typedef struct dot11_quiet dot11_quiet_t; 871*4882a593Smuzhiyun 872*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct chan_map_tuple { 873*4882a593Smuzhiyun uint8 channel; 874*4882a593Smuzhiyun uint8 map; 875*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 876*4882a593Smuzhiyun typedef struct chan_map_tuple chan_map_tuple_t; 877*4882a593Smuzhiyun 878*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ibss_dfs { 879*4882a593Smuzhiyun uint8 id; 880*4882a593Smuzhiyun uint8 len; 881*4882a593Smuzhiyun uint8 eaddr[ETHER_ADDR_LEN]; 882*4882a593Smuzhiyun uint8 interval; 883*4882a593Smuzhiyun chan_map_tuple_t map[1]; 884*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 885*4882a593Smuzhiyun typedef struct dot11_ibss_dfs dot11_ibss_dfs_t; 886*4882a593Smuzhiyun 887*4882a593Smuzhiyun /* WME Elements */ 888*4882a593Smuzhiyun #define WME_OUI "\x00\x50\xf2" /* WME OUI */ 889*4882a593Smuzhiyun #define WME_OUI_LEN 3 890*4882a593Smuzhiyun #define WME_OUI_TYPE 2 /* WME type */ 891*4882a593Smuzhiyun #define WME_TYPE 2 /* WME type, deprecated */ 892*4882a593Smuzhiyun #define WME_SUBTYPE_IE 0 /* Information Element */ 893*4882a593Smuzhiyun #define WME_SUBTYPE_PARAM_IE 1 /* Parameter Element */ 894*4882a593Smuzhiyun #define WME_SUBTYPE_TSPEC 2 /* Traffic Specification */ 895*4882a593Smuzhiyun #define WME_VER 1 /* WME version */ 896*4882a593Smuzhiyun 897*4882a593Smuzhiyun /* WME Access Category Indices (ACIs) */ 898*4882a593Smuzhiyun #define AC_BE 0 /* Best Effort */ 899*4882a593Smuzhiyun #define AC_BK 1 /* Background */ 900*4882a593Smuzhiyun #define AC_VI 2 /* Video */ 901*4882a593Smuzhiyun #define AC_VO 3 /* Voice */ 902*4882a593Smuzhiyun #define AC_COUNT 4 /* number of ACs */ 903*4882a593Smuzhiyun 904*4882a593Smuzhiyun typedef uint8 ac_bitmap_t; /* AC bitmap of (1 << AC_xx) */ 905*4882a593Smuzhiyun 906*4882a593Smuzhiyun #define AC_BITMAP_NONE 0x0 /* No ACs */ 907*4882a593Smuzhiyun #define AC_BITMAP_ALL 0xf /* All ACs */ 908*4882a593Smuzhiyun #define AC_BITMAP_TST(ab, ac) (((ab) & (1 << (ac))) != 0) 909*4882a593Smuzhiyun #define AC_BITMAP_SET(ab, ac) (((ab) |= (1 << (ac)))) 910*4882a593Smuzhiyun #define AC_BITMAP_RESET(ab, ac) (((ab) &= ~(1 << (ac)))) 911*4882a593Smuzhiyun 912*4882a593Smuzhiyun /* Management PKT Lifetime indices */ 913*4882a593Smuzhiyun /* Removing flag checks 'WLTEST' 914*4882a593Smuzhiyun * while merging MERGE BIS120RC4 to DINGO2 915*4882a593Smuzhiyun */ 916*4882a593Smuzhiyun #define MGMT_ALL 0xffff 917*4882a593Smuzhiyun #define MGMT_AUTH_LT FC_SUBTYPE_AUTH 918*4882a593Smuzhiyun #define MGMT_ASSOC_LT FC_SUBTYPE_ASSOC_REQ 919*4882a593Smuzhiyun 920*4882a593Smuzhiyun /** WME Information Element (IE) */ 921*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct wme_ie { 922*4882a593Smuzhiyun uint8 oui[3]; 923*4882a593Smuzhiyun uint8 type; 924*4882a593Smuzhiyun uint8 subtype; 925*4882a593Smuzhiyun uint8 version; 926*4882a593Smuzhiyun uint8 qosinfo; 927*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 928*4882a593Smuzhiyun typedef struct wme_ie wme_ie_t; 929*4882a593Smuzhiyun #define WME_IE_LEN 7 /* WME IE length */ 930*4882a593Smuzhiyun 931*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct edcf_acparam { 932*4882a593Smuzhiyun uint8 ACI; 933*4882a593Smuzhiyun uint8 ECW; 934*4882a593Smuzhiyun uint16 TXOP; /* stored in network order (ls octet first) */ 935*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 936*4882a593Smuzhiyun typedef struct edcf_acparam edcf_acparam_t; 937*4882a593Smuzhiyun 938*4882a593Smuzhiyun /** WME Parameter Element (PE) */ 939*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct wme_param_ie { 940*4882a593Smuzhiyun uint8 oui[3]; 941*4882a593Smuzhiyun uint8 type; 942*4882a593Smuzhiyun uint8 subtype; 943*4882a593Smuzhiyun uint8 version; 944*4882a593Smuzhiyun uint8 qosinfo; 945*4882a593Smuzhiyun uint8 rsvd; 946*4882a593Smuzhiyun edcf_acparam_t acparam[AC_COUNT]; 947*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 948*4882a593Smuzhiyun typedef struct wme_param_ie wme_param_ie_t; 949*4882a593Smuzhiyun #define WME_PARAM_IE_LEN 24 /* WME Parameter IE length */ 950*4882a593Smuzhiyun 951*4882a593Smuzhiyun /* QoS Info field for IE as sent from AP */ 952*4882a593Smuzhiyun #define WME_QI_AP_APSD_MASK 0x80 /* U-APSD Supported mask */ 953*4882a593Smuzhiyun #define WME_QI_AP_APSD_SHIFT 7 /* U-APSD Supported shift */ 954*4882a593Smuzhiyun #define WME_QI_AP_COUNT_MASK 0x0f /* Parameter set count mask */ 955*4882a593Smuzhiyun #define WME_QI_AP_COUNT_SHIFT 0 /* Parameter set count shift */ 956*4882a593Smuzhiyun 957*4882a593Smuzhiyun /* QoS Info field for IE as sent from STA */ 958*4882a593Smuzhiyun #define WME_QI_STA_MAXSPLEN_MASK 0x60 /* Max Service Period Length mask */ 959*4882a593Smuzhiyun #define WME_QI_STA_MAXSPLEN_SHIFT 5 /* Max Service Period Length shift */ 960*4882a593Smuzhiyun #define WME_QI_STA_APSD_ALL_MASK 0xf /* APSD all AC bits mask */ 961*4882a593Smuzhiyun #define WME_QI_STA_APSD_ALL_SHIFT 0 /* APSD all AC bits shift */ 962*4882a593Smuzhiyun #define WME_QI_STA_APSD_BE_MASK 0x8 /* APSD AC_BE mask */ 963*4882a593Smuzhiyun #define WME_QI_STA_APSD_BE_SHIFT 3 /* APSD AC_BE shift */ 964*4882a593Smuzhiyun #define WME_QI_STA_APSD_BK_MASK 0x4 /* APSD AC_BK mask */ 965*4882a593Smuzhiyun #define WME_QI_STA_APSD_BK_SHIFT 2 /* APSD AC_BK shift */ 966*4882a593Smuzhiyun #define WME_QI_STA_APSD_VI_MASK 0x2 /* APSD AC_VI mask */ 967*4882a593Smuzhiyun #define WME_QI_STA_APSD_VI_SHIFT 1 /* APSD AC_VI shift */ 968*4882a593Smuzhiyun #define WME_QI_STA_APSD_VO_MASK 0x1 /* APSD AC_VO mask */ 969*4882a593Smuzhiyun #define WME_QI_STA_APSD_VO_SHIFT 0 /* APSD AC_VO shift */ 970*4882a593Smuzhiyun 971*4882a593Smuzhiyun /* ACI */ 972*4882a593Smuzhiyun #define EDCF_AIFSN_MIN 1 /* AIFSN minimum value */ 973*4882a593Smuzhiyun #define EDCF_AIFSN_MAX 15 /* AIFSN maximum value */ 974*4882a593Smuzhiyun #define EDCF_AIFSN_MASK 0x0f /* AIFSN mask */ 975*4882a593Smuzhiyun #define EDCF_ACM_MASK 0x10 /* ACM mask */ 976*4882a593Smuzhiyun #define EDCF_ACI_MASK 0x60 /* ACI mask */ 977*4882a593Smuzhiyun #define EDCF_ACI_SHIFT 5 /* ACI shift */ 978*4882a593Smuzhiyun #define EDCF_AIFSN_SHIFT 12 /* 4 MSB(0xFFF) in ifs_ctl for AC idx */ 979*4882a593Smuzhiyun 980*4882a593Smuzhiyun /* ECW */ 981*4882a593Smuzhiyun #define EDCF_ECW_MIN 0 /* cwmin/cwmax exponent minimum value */ 982*4882a593Smuzhiyun #define EDCF_ECW_MAX 15 /* cwmin/cwmax exponent maximum value */ 983*4882a593Smuzhiyun #define EDCF_ECW2CW(exp) ((1 << (exp)) - 1) 984*4882a593Smuzhiyun #define EDCF_ECWMIN_MASK 0x0f /* cwmin exponent form mask */ 985*4882a593Smuzhiyun #define EDCF_ECWMAX_MASK 0xf0 /* cwmax exponent form mask */ 986*4882a593Smuzhiyun #define EDCF_ECWMAX_SHIFT 4 /* cwmax exponent form shift */ 987*4882a593Smuzhiyun 988*4882a593Smuzhiyun /* TXOP */ 989*4882a593Smuzhiyun #define EDCF_TXOP_MIN 0 /* TXOP minimum value */ 990*4882a593Smuzhiyun #define EDCF_TXOP_MAX 65535 /* TXOP maximum value */ 991*4882a593Smuzhiyun #define EDCF_TXOP2USEC(txop) ((txop) << 5) 992*4882a593Smuzhiyun 993*4882a593Smuzhiyun /* Default BE ACI value for non-WME connection STA */ 994*4882a593Smuzhiyun #define NON_EDCF_AC_BE_ACI_STA 0x02 995*4882a593Smuzhiyun 996*4882a593Smuzhiyun /* Default EDCF parameters that AP advertises for STA to use; WMM draft Table 12 */ 997*4882a593Smuzhiyun #define EDCF_AC_BE_ACI_STA 0x03 /* STA ACI value for best effort AC */ 998*4882a593Smuzhiyun #define EDCF_AC_BE_ECW_STA 0xA4 /* STA ECW value for best effort AC */ 999*4882a593Smuzhiyun #define EDCF_AC_BE_TXOP_STA 0x0000 /* STA TXOP value for best effort AC */ 1000*4882a593Smuzhiyun #define EDCF_AC_BK_ACI_STA 0x27 /* STA ACI value for background AC */ 1001*4882a593Smuzhiyun #define EDCF_AC_BK_ECW_STA 0xA4 /* STA ECW value for background AC */ 1002*4882a593Smuzhiyun #define EDCF_AC_BK_TXOP_STA 0x0000 /* STA TXOP value for background AC */ 1003*4882a593Smuzhiyun #define EDCF_AC_VI_ACI_STA 0x42 /* STA ACI value for video AC */ 1004*4882a593Smuzhiyun #define EDCF_AC_VI_ECW_STA 0x43 /* STA ECW value for video AC */ 1005*4882a593Smuzhiyun #define EDCF_AC_VI_TXOP_STA 0x005e /* STA TXOP value for video AC */ 1006*4882a593Smuzhiyun #define EDCF_AC_VO_ACI_STA 0x62 /* STA ACI value for audio AC */ 1007*4882a593Smuzhiyun #define EDCF_AC_VO_ECW_STA 0x32 /* STA ECW value for audio AC */ 1008*4882a593Smuzhiyun #define EDCF_AC_VO_TXOP_STA 0x002f /* STA TXOP value for audio AC */ 1009*4882a593Smuzhiyun 1010*4882a593Smuzhiyun /* Default EDCF parameters that AP uses; WMM draft Table 14 */ 1011*4882a593Smuzhiyun #define EDCF_AC_BE_ACI_AP 0x03 /* AP ACI value for best effort AC */ 1012*4882a593Smuzhiyun #define EDCF_AC_BE_ECW_AP 0x64 /* AP ECW value for best effort AC */ 1013*4882a593Smuzhiyun #define EDCF_AC_BE_TXOP_AP 0x0000 /* AP TXOP value for best effort AC */ 1014*4882a593Smuzhiyun #define EDCF_AC_BK_ACI_AP 0x27 /* AP ACI value for background AC */ 1015*4882a593Smuzhiyun #define EDCF_AC_BK_ECW_AP 0xA4 /* AP ECW value for background AC */ 1016*4882a593Smuzhiyun #define EDCF_AC_BK_TXOP_AP 0x0000 /* AP TXOP value for background AC */ 1017*4882a593Smuzhiyun #define EDCF_AC_VI_ACI_AP 0x41 /* AP ACI value for video AC */ 1018*4882a593Smuzhiyun #define EDCF_AC_VI_ECW_AP 0x43 /* AP ECW value for video AC */ 1019*4882a593Smuzhiyun #define EDCF_AC_VI_TXOP_AP 0x005e /* AP TXOP value for video AC */ 1020*4882a593Smuzhiyun #define EDCF_AC_VO_ACI_AP 0x61 /* AP ACI value for audio AC */ 1021*4882a593Smuzhiyun #define EDCF_AC_VO_ECW_AP 0x32 /* AP ECW value for audio AC */ 1022*4882a593Smuzhiyun #define EDCF_AC_VO_TXOP_AP 0x002f /* AP TXOP value for audio AC */ 1023*4882a593Smuzhiyun 1024*4882a593Smuzhiyun /** EDCA Parameter IE */ 1025*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct edca_param_ie { 1026*4882a593Smuzhiyun uint8 qosinfo; 1027*4882a593Smuzhiyun uint8 rsvd; 1028*4882a593Smuzhiyun edcf_acparam_t acparam[AC_COUNT]; 1029*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 1030*4882a593Smuzhiyun typedef struct edca_param_ie edca_param_ie_t; 1031*4882a593Smuzhiyun #define EDCA_PARAM_IE_LEN 18 /* EDCA Parameter IE length */ 1032*4882a593Smuzhiyun 1033*4882a593Smuzhiyun /** QoS Capability IE */ 1034*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct qos_cap_ie { 1035*4882a593Smuzhiyun uint8 qosinfo; 1036*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 1037*4882a593Smuzhiyun typedef struct qos_cap_ie qos_cap_ie_t; 1038*4882a593Smuzhiyun 1039*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_qbss_load_ie { 1040*4882a593Smuzhiyun uint8 id; /* 11, DOT11_MNG_QBSS_LOAD_ID */ 1041*4882a593Smuzhiyun uint8 length; 1042*4882a593Smuzhiyun uint16 station_count; /* total number of STAs associated */ 1043*4882a593Smuzhiyun uint8 channel_utilization; /* % of time, normalized to 255, QAP sensed medium busy */ 1044*4882a593Smuzhiyun uint16 aac; /* available admission capacity */ 1045*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 1046*4882a593Smuzhiyun typedef struct dot11_qbss_load_ie dot11_qbss_load_ie_t; 1047*4882a593Smuzhiyun #define BSS_LOAD_IE_SIZE 7 /* BSS load IE size */ 1048*4882a593Smuzhiyun 1049*4882a593Smuzhiyun #define WLC_QBSS_LOAD_CHAN_FREE_MAX 0xff /* max for channel free score */ 1050*4882a593Smuzhiyun 1051*4882a593Smuzhiyun /* Estimated Service Parameters (ESP) IE - 802.11-2016 9.4.2.174 */ 1052*4882a593Smuzhiyun typedef BWL_PRE_PACKED_STRUCT struct dot11_esp_ie { 1053*4882a593Smuzhiyun uint8 id; 1054*4882a593Smuzhiyun uint8 length; 1055*4882a593Smuzhiyun uint8 id_ext; 1056*4882a593Smuzhiyun /* variable len info */ 1057*4882a593Smuzhiyun uint8 esp_info_lists[]; 1058*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT dot11_esp_ie_t; 1059*4882a593Smuzhiyun 1060*4882a593Smuzhiyun #define DOT11_ESP_IE_HDR_SIZE (OFFSETOF(dot11_esp_ie_t, esp_info_lists)) 1061*4882a593Smuzhiyun 1062*4882a593Smuzhiyun /* ESP Information list - 802.11-2016 9.4.2.174 */ 1063*4882a593Smuzhiyun typedef BWL_PRE_PACKED_STRUCT struct dot11_esp_ie_info_list { 1064*4882a593Smuzhiyun /* acess category, data format, ba win size */ 1065*4882a593Smuzhiyun uint8 ac_df_baws; 1066*4882a593Smuzhiyun /* estimated air time fraction */ 1067*4882a593Smuzhiyun uint8 eat_frac; 1068*4882a593Smuzhiyun /* data PPDU duration target (50us units) */ 1069*4882a593Smuzhiyun uint8 ppdu_dur; 1070*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT dot11_esp_ie_info_list_t; 1071*4882a593Smuzhiyun 1072*4882a593Smuzhiyun #define DOT11_ESP_IE_INFO_LIST_SIZE (sizeof(dot11_esp_ie_info_list_t)) 1073*4882a593Smuzhiyun 1074*4882a593Smuzhiyun #define DOT11_ESP_NBR_INFO_LISTS 4u /* max nbr of esp information lists */ 1075*4882a593Smuzhiyun #define DOT11_ESP_INFO_LIST_AC_BK 0u /* access category of esp information list AC_BK */ 1076*4882a593Smuzhiyun #define DOT11_ESP_INFO_LIST_AC_BE 1u /* access category of esp information list AC_BE */ 1077*4882a593Smuzhiyun #define DOT11_ESP_INFO_LIST_AC_VI 2u /* access category of esp information list AC_VI */ 1078*4882a593Smuzhiyun #define DOT11_ESP_INFO_LIST_AC_VO 3u /* access category of esp information list AC_VO */ 1079*4882a593Smuzhiyun 1080*4882a593Smuzhiyun #define DOT11_ESP_INFO_LIST_DF_MASK 0x18 /* Data Format Mask */ 1081*4882a593Smuzhiyun #define DOT11_ESP_INFO_LIST_BAWS_MASK 0xE0 /* BA window size mask */ 1082*4882a593Smuzhiyun 1083*4882a593Smuzhiyun /* nom_msdu_size */ 1084*4882a593Smuzhiyun #define FIXED_MSDU_SIZE 0x8000 /* MSDU size is fixed */ 1085*4882a593Smuzhiyun #define MSDU_SIZE_MASK 0x7fff /* (Nominal or fixed) MSDU size */ 1086*4882a593Smuzhiyun 1087*4882a593Smuzhiyun /* surplus_bandwidth */ 1088*4882a593Smuzhiyun /* Represented as 3 bits of integer, binary point, 13 bits fraction */ 1089*4882a593Smuzhiyun #define INTEGER_SHIFT 13 /* integer shift */ 1090*4882a593Smuzhiyun #define FRACTION_MASK 0x1FFF /* fraction mask */ 1091*4882a593Smuzhiyun 1092*4882a593Smuzhiyun /** Management Notification Frame */ 1093*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_management_notification { 1094*4882a593Smuzhiyun uint8 category; /* DOT11_ACTION_NOTIFICATION */ 1095*4882a593Smuzhiyun uint8 action; 1096*4882a593Smuzhiyun uint8 token; 1097*4882a593Smuzhiyun uint8 status; 1098*4882a593Smuzhiyun uint8 data[1]; /* Elements */ 1099*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 1100*4882a593Smuzhiyun #define DOT11_MGMT_NOTIFICATION_LEN 4 /* Fixed length */ 1101*4882a593Smuzhiyun 1102*4882a593Smuzhiyun /** Timeout Interval IE */ 1103*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct ti_ie { 1104*4882a593Smuzhiyun uint8 ti_type; 1105*4882a593Smuzhiyun uint32 ti_val; 1106*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 1107*4882a593Smuzhiyun typedef struct ti_ie ti_ie_t; 1108*4882a593Smuzhiyun #define TI_TYPE_REASSOC_DEADLINE 1 1109*4882a593Smuzhiyun #define TI_TYPE_KEY_LIFETIME 2 1110*4882a593Smuzhiyun 1111*4882a593Smuzhiyun #ifndef CISCO_AIRONET_OUI 1112*4882a593Smuzhiyun #define CISCO_AIRONET_OUI "\x00\x40\x96" /* Cisco AIRONET OUI */ 1113*4882a593Smuzhiyun #endif 1114*4882a593Smuzhiyun /* QoS FastLane IE. */ 1115*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct ccx_qfl_ie { 1116*4882a593Smuzhiyun uint8 id; /* 221, DOT11_MNG_VS_ID */ 1117*4882a593Smuzhiyun uint8 length; /* 5 */ 1118*4882a593Smuzhiyun uint8 oui[3]; /* 00:40:96 */ 1119*4882a593Smuzhiyun uint8 type; /* 11 */ 1120*4882a593Smuzhiyun uint8 data; 1121*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 1122*4882a593Smuzhiyun typedef struct ccx_qfl_ie ccx_qfl_ie_t; 1123*4882a593Smuzhiyun #define CCX_QFL_IE_TYPE 11 1124*4882a593Smuzhiyun #define CCX_QFL_ENABLE_SHIFT 5 1125*4882a593Smuzhiyun #define CCX_QFL_ENALBE (1 << CCX_QFL_ENABLE_SHIFT) 1126*4882a593Smuzhiyun 1127*4882a593Smuzhiyun /* WME Action Codes */ 1128*4882a593Smuzhiyun #define WME_ADDTS_REQUEST 0 /* WME ADDTS request */ 1129*4882a593Smuzhiyun #define WME_ADDTS_RESPONSE 1 /* WME ADDTS response */ 1130*4882a593Smuzhiyun #define WME_DELTS_REQUEST 2 /* WME DELTS request */ 1131*4882a593Smuzhiyun 1132*4882a593Smuzhiyun /* WME Setup Response Status Codes */ 1133*4882a593Smuzhiyun #define WME_ADMISSION_ACCEPTED 0 /* WME admission accepted */ 1134*4882a593Smuzhiyun #define WME_INVALID_PARAMETERS 1 /* WME invalide parameters */ 1135*4882a593Smuzhiyun #define WME_ADMISSION_REFUSED 3 /* WME admission refused */ 1136*4882a593Smuzhiyun 1137*4882a593Smuzhiyun /* Macro to take a pointer to a beacon or probe response 1138*4882a593Smuzhiyun * body and return the char* pointer to the SSID info element 1139*4882a593Smuzhiyun */ 1140*4882a593Smuzhiyun #define BCN_PRB_SSID(body) ((char*)(body) + DOT11_BCN_PRB_LEN) 1141*4882a593Smuzhiyun 1142*4882a593Smuzhiyun /* Authentication frame payload constants */ 1143*4882a593Smuzhiyun #define DOT11_OPEN_SYSTEM 0 /* d11 open authentication */ 1144*4882a593Smuzhiyun #define DOT11_SHARED_KEY 1 /* d11 shared authentication */ 1145*4882a593Smuzhiyun #define DOT11_FAST_BSS 2 /* d11 fast bss authentication */ 1146*4882a593Smuzhiyun #define DOT11_SAE 3 /* d11 simultaneous authentication of equals */ 1147*4882a593Smuzhiyun #define DOT11_FILS_SKEY 4 /* d11 fils shared key authentication w/o pfs */ 1148*4882a593Smuzhiyun #define DOT11_FILS_SKEY_PFS 5 /* d11 fils shared key authentication w/ pfs */ 1149*4882a593Smuzhiyun #define DOT11_FILS_PKEY 6 /* d11 fils public key authentication */ 1150*4882a593Smuzhiyun #define DOT11_MAX_AUTH_ALG DOT11_FILS_PKEY /* maximum value of an auth alg */ 1151*4882a593Smuzhiyun #define DOT11_CHALLENGE_LEN 128 /* d11 challenge text length */ 1152*4882a593Smuzhiyun 1153*4882a593Smuzhiyun /* Frame control macros */ 1154*4882a593Smuzhiyun #define FC_PVER_MASK 0x3 /* PVER mask */ 1155*4882a593Smuzhiyun #define FC_PVER_SHIFT 0 /* PVER shift */ 1156*4882a593Smuzhiyun #define FC_TYPE_MASK 0xC /* type mask */ 1157*4882a593Smuzhiyun #define FC_TYPE_SHIFT 2 /* type shift */ 1158*4882a593Smuzhiyun #define FC_SUBTYPE_MASK 0xF0 /* subtype mask */ 1159*4882a593Smuzhiyun #define FC_SUBTYPE_SHIFT 4 /* subtype shift */ 1160*4882a593Smuzhiyun #define FC_TODS 0x100 /* to DS */ 1161*4882a593Smuzhiyun #define FC_TODS_SHIFT 8 /* to DS shift */ 1162*4882a593Smuzhiyun #define FC_FROMDS 0x200 /* from DS */ 1163*4882a593Smuzhiyun #define FC_FROMDS_SHIFT 9 /* from DS shift */ 1164*4882a593Smuzhiyun #define FC_MOREFRAG 0x400 /* more frag. */ 1165*4882a593Smuzhiyun #define FC_MOREFRAG_SHIFT 10 /* more frag. shift */ 1166*4882a593Smuzhiyun #define FC_RETRY 0x800 /* retry */ 1167*4882a593Smuzhiyun #define FC_RETRY_SHIFT 11 /* retry shift */ 1168*4882a593Smuzhiyun #define FC_PM 0x1000 /* PM */ 1169*4882a593Smuzhiyun #define FC_PM_SHIFT 12 /* PM shift */ 1170*4882a593Smuzhiyun #define FC_MOREDATA 0x2000 /* more data */ 1171*4882a593Smuzhiyun #define FC_MOREDATA_SHIFT 13 /* more data shift */ 1172*4882a593Smuzhiyun #define FC_WEP 0x4000 /* WEP */ 1173*4882a593Smuzhiyun #define FC_WEP_SHIFT 14 /* WEP shift */ 1174*4882a593Smuzhiyun #define FC_ORDER 0x8000 /* order */ 1175*4882a593Smuzhiyun #define FC_ORDER_SHIFT 15 /* order shift */ 1176*4882a593Smuzhiyun 1177*4882a593Smuzhiyun /* sequence control macros */ 1178*4882a593Smuzhiyun #define SEQNUM_SHIFT 4 /* seq. number shift */ 1179*4882a593Smuzhiyun #define SEQNUM_MAX 0x1000 /* max seqnum + 1 */ 1180*4882a593Smuzhiyun #define FRAGNUM_MASK 0xF /* frag. number mask */ 1181*4882a593Smuzhiyun 1182*4882a593Smuzhiyun /* Frame Control type/subtype defs */ 1183*4882a593Smuzhiyun 1184*4882a593Smuzhiyun /* FC Types */ 1185*4882a593Smuzhiyun #define FC_TYPE_MNG 0 /* management type */ 1186*4882a593Smuzhiyun #define FC_TYPE_CTL 1 /* control type */ 1187*4882a593Smuzhiyun #define FC_TYPE_DATA 2 /* data type */ 1188*4882a593Smuzhiyun 1189*4882a593Smuzhiyun /* Management Subtypes */ 1190*4882a593Smuzhiyun #define FC_SUBTYPE_ASSOC_REQ 0 /* assoc. request */ 1191*4882a593Smuzhiyun #define FC_SUBTYPE_ASSOC_RESP 1 /* assoc. response */ 1192*4882a593Smuzhiyun #define FC_SUBTYPE_REASSOC_REQ 2 /* reassoc. request */ 1193*4882a593Smuzhiyun #define FC_SUBTYPE_REASSOC_RESP 3 /* reassoc. response */ 1194*4882a593Smuzhiyun #define FC_SUBTYPE_PROBE_REQ 4 /* probe request */ 1195*4882a593Smuzhiyun #define FC_SUBTYPE_PROBE_RESP 5 /* probe response */ 1196*4882a593Smuzhiyun #define FC_SUBTYPE_BEACON 8 /* beacon */ 1197*4882a593Smuzhiyun #define FC_SUBTYPE_ATIM 9 /* ATIM */ 1198*4882a593Smuzhiyun #define FC_SUBTYPE_DISASSOC 10 /* disassoc. */ 1199*4882a593Smuzhiyun #define FC_SUBTYPE_AUTH 11 /* authentication */ 1200*4882a593Smuzhiyun #define FC_SUBTYPE_DEAUTH 12 /* de-authentication */ 1201*4882a593Smuzhiyun #define FC_SUBTYPE_ACTION 13 /* action */ 1202*4882a593Smuzhiyun #define FC_SUBTYPE_ACTION_NOACK 14 /* action no-ack */ 1203*4882a593Smuzhiyun 1204*4882a593Smuzhiyun /* Control Subtypes */ 1205*4882a593Smuzhiyun #define FC_SUBTYPE_TRIGGER 2 /* Trigger frame */ 1206*4882a593Smuzhiyun #define FC_SUBTYPE_NDPA 5 /* NDPA */ 1207*4882a593Smuzhiyun #define FC_SUBTYPE_CTL_WRAPPER 7 /* Control Wrapper */ 1208*4882a593Smuzhiyun #define FC_SUBTYPE_BLOCKACK_REQ 8 /* Block Ack Req */ 1209*4882a593Smuzhiyun #define FC_SUBTYPE_BLOCKACK 9 /* Block Ack */ 1210*4882a593Smuzhiyun #define FC_SUBTYPE_PS_POLL 10 /* PS poll */ 1211*4882a593Smuzhiyun #define FC_SUBTYPE_RTS 11 /* RTS */ 1212*4882a593Smuzhiyun #define FC_SUBTYPE_CTS 12 /* CTS */ 1213*4882a593Smuzhiyun #define FC_SUBTYPE_ACK 13 /* ACK */ 1214*4882a593Smuzhiyun #define FC_SUBTYPE_CF_END 14 /* CF-END */ 1215*4882a593Smuzhiyun #define FC_SUBTYPE_CF_END_ACK 15 /* CF-END ACK */ 1216*4882a593Smuzhiyun 1217*4882a593Smuzhiyun /* Data Subtypes */ 1218*4882a593Smuzhiyun #define FC_SUBTYPE_DATA 0 /* Data */ 1219*4882a593Smuzhiyun #define FC_SUBTYPE_DATA_CF_ACK 1 /* Data + CF-ACK */ 1220*4882a593Smuzhiyun #define FC_SUBTYPE_DATA_CF_POLL 2 /* Data + CF-Poll */ 1221*4882a593Smuzhiyun #define FC_SUBTYPE_DATA_CF_ACK_POLL 3 /* Data + CF-Ack + CF-Poll */ 1222*4882a593Smuzhiyun #define FC_SUBTYPE_NULL 4 /* Null */ 1223*4882a593Smuzhiyun #define FC_SUBTYPE_CF_ACK 5 /* CF-Ack */ 1224*4882a593Smuzhiyun #define FC_SUBTYPE_CF_POLL 6 /* CF-Poll */ 1225*4882a593Smuzhiyun #define FC_SUBTYPE_CF_ACK_POLL 7 /* CF-Ack + CF-Poll */ 1226*4882a593Smuzhiyun #define FC_SUBTYPE_QOS_DATA 8 /* QoS Data */ 1227*4882a593Smuzhiyun #define FC_SUBTYPE_QOS_DATA_CF_ACK 9 /* QoS Data + CF-Ack */ 1228*4882a593Smuzhiyun #define FC_SUBTYPE_QOS_DATA_CF_POLL 10 /* QoS Data + CF-Poll */ 1229*4882a593Smuzhiyun #define FC_SUBTYPE_QOS_DATA_CF_ACK_POLL 11 /* QoS Data + CF-Ack + CF-Poll */ 1230*4882a593Smuzhiyun #define FC_SUBTYPE_QOS_NULL 12 /* QoS Null */ 1231*4882a593Smuzhiyun #define FC_SUBTYPE_QOS_CF_POLL 14 /* QoS CF-Poll */ 1232*4882a593Smuzhiyun #define FC_SUBTYPE_QOS_CF_ACK_POLL 15 /* QoS CF-Ack + CF-Poll */ 1233*4882a593Smuzhiyun 1234*4882a593Smuzhiyun /* Data Subtype Groups */ 1235*4882a593Smuzhiyun #define FC_SUBTYPE_ANY_QOS(s) (((s) & 8) != 0) 1236*4882a593Smuzhiyun #define FC_SUBTYPE_ANY_NULL(s) (((s) & 4) != 0) 1237*4882a593Smuzhiyun #define FC_SUBTYPE_ANY_CF_POLL(s) (((s) & 2) != 0) 1238*4882a593Smuzhiyun #define FC_SUBTYPE_ANY_CF_ACK(s) (((s) & 1) != 0) 1239*4882a593Smuzhiyun #define FC_SUBTYPE_ANY_PSPOLL(s) (((s) & 10) != 0) 1240*4882a593Smuzhiyun 1241*4882a593Smuzhiyun /* Type/Subtype Combos */ 1242*4882a593Smuzhiyun #define FC_KIND_MASK (FC_TYPE_MASK | FC_SUBTYPE_MASK) /* FC kind mask */ 1243*4882a593Smuzhiyun 1244*4882a593Smuzhiyun #define FC_KIND(t, s) (((t) << FC_TYPE_SHIFT) | ((s) << FC_SUBTYPE_SHIFT)) /* FC kind */ 1245*4882a593Smuzhiyun 1246*4882a593Smuzhiyun #define FC_SUBTYPE(fc) (((fc) & FC_SUBTYPE_MASK) >> FC_SUBTYPE_SHIFT) /* Subtype from FC */ 1247*4882a593Smuzhiyun #define FC_TYPE(fc) (((fc) & FC_TYPE_MASK) >> FC_TYPE_SHIFT) /* Type from FC */ 1248*4882a593Smuzhiyun 1249*4882a593Smuzhiyun #define FC_ASSOC_REQ FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_ASSOC_REQ) /* assoc. request */ 1250*4882a593Smuzhiyun #define FC_ASSOC_RESP FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_ASSOC_RESP) /* assoc. response */ 1251*4882a593Smuzhiyun #define FC_REASSOC_REQ FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_REASSOC_REQ) /* reassoc. request */ 1252*4882a593Smuzhiyun #define FC_REASSOC_RESP FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_REASSOC_RESP) /* reassoc. response */ 1253*4882a593Smuzhiyun #define FC_PROBE_REQ FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_PROBE_REQ) /* probe request */ 1254*4882a593Smuzhiyun #define FC_PROBE_RESP FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_PROBE_RESP) /* probe response */ 1255*4882a593Smuzhiyun #define FC_BEACON FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_BEACON) /* beacon */ 1256*4882a593Smuzhiyun #define FC_ATIM FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_ATIM) /* ATIM */ 1257*4882a593Smuzhiyun #define FC_DISASSOC FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_DISASSOC) /* disassoc */ 1258*4882a593Smuzhiyun #define FC_AUTH FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_AUTH) /* authentication */ 1259*4882a593Smuzhiyun #define FC_DEAUTH FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_DEAUTH) /* deauthentication */ 1260*4882a593Smuzhiyun #define FC_ACTION FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_ACTION) /* action */ 1261*4882a593Smuzhiyun #define FC_ACTION_NOACK FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_ACTION_NOACK) /* action no-ack */ 1262*4882a593Smuzhiyun 1263*4882a593Smuzhiyun #define FC_CTL_TRIGGER FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_TRIGGER) /* Trigger frame */ 1264*4882a593Smuzhiyun #define FC_CTL_NDPA FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_NDPA) /* NDPA frame */ 1265*4882a593Smuzhiyun #define FC_CTL_WRAPPER FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_CTL_WRAPPER) /* Control Wrapper */ 1266*4882a593Smuzhiyun #define FC_BLOCKACK_REQ FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_BLOCKACK_REQ) /* Block Ack Req */ 1267*4882a593Smuzhiyun #define FC_BLOCKACK FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_BLOCKACK) /* Block Ack */ 1268*4882a593Smuzhiyun #define FC_PS_POLL FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_PS_POLL) /* PS poll */ 1269*4882a593Smuzhiyun #define FC_RTS FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_RTS) /* RTS */ 1270*4882a593Smuzhiyun #define FC_CTS FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_CTS) /* CTS */ 1271*4882a593Smuzhiyun #define FC_ACK FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_ACK) /* ACK */ 1272*4882a593Smuzhiyun #define FC_CF_END FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_CF_END) /* CF-END */ 1273*4882a593Smuzhiyun #define FC_CF_END_ACK FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_CF_END_ACK) /* CF-END ACK */ 1274*4882a593Smuzhiyun 1275*4882a593Smuzhiyun #define FC_DATA FC_KIND(FC_TYPE_DATA, FC_SUBTYPE_DATA) /* data */ 1276*4882a593Smuzhiyun #define FC_NULL_DATA FC_KIND(FC_TYPE_DATA, FC_SUBTYPE_NULL) /* null data */ 1277*4882a593Smuzhiyun #define FC_DATA_CF_ACK FC_KIND(FC_TYPE_DATA, FC_SUBTYPE_DATA_CF_ACK) /* data CF ACK */ 1278*4882a593Smuzhiyun #define FC_QOS_DATA FC_KIND(FC_TYPE_DATA, FC_SUBTYPE_QOS_DATA) /* QoS data */ 1279*4882a593Smuzhiyun #define FC_QOS_NULL FC_KIND(FC_TYPE_DATA, FC_SUBTYPE_QOS_NULL) /* QoS null */ 1280*4882a593Smuzhiyun 1281*4882a593Smuzhiyun /* QoS Control Field */ 1282*4882a593Smuzhiyun 1283*4882a593Smuzhiyun /* 802.1D Priority */ 1284*4882a593Smuzhiyun #define QOS_PRIO_SHIFT 0 /* QoS priority shift */ 1285*4882a593Smuzhiyun #define QOS_PRIO_MASK 0x0007 /* QoS priority mask */ 1286*4882a593Smuzhiyun #define QOS_PRIO(qos) (((qos) & QOS_PRIO_MASK) >> QOS_PRIO_SHIFT) /* QoS priority */ 1287*4882a593Smuzhiyun 1288*4882a593Smuzhiyun /* Traffic Identifier */ 1289*4882a593Smuzhiyun #define QOS_TID_SHIFT 0 /* QoS TID shift */ 1290*4882a593Smuzhiyun #define QOS_TID_MASK 0x000f /* QoS TID mask */ 1291*4882a593Smuzhiyun #define QOS_TID(qos) (((qos) & QOS_TID_MASK) >> QOS_TID_SHIFT) /* QoS TID */ 1292*4882a593Smuzhiyun 1293*4882a593Smuzhiyun /* End of Service Period (U-APSD) */ 1294*4882a593Smuzhiyun #define QOS_EOSP_SHIFT 4 /* QoS End of Service Period shift */ 1295*4882a593Smuzhiyun #define QOS_EOSP_MASK 0x0010 /* QoS End of Service Period mask */ 1296*4882a593Smuzhiyun #define QOS_EOSP(qos) (((qos) & QOS_EOSP_MASK) >> QOS_EOSP_SHIFT) /* Qos EOSP */ 1297*4882a593Smuzhiyun 1298*4882a593Smuzhiyun /* Ack Policy */ 1299*4882a593Smuzhiyun #define QOS_ACK_NORMAL_ACK 0 /* Normal Ack */ 1300*4882a593Smuzhiyun #define QOS_ACK_NO_ACK 1 /* No Ack (eg mcast) */ 1301*4882a593Smuzhiyun #define QOS_ACK_NO_EXP_ACK 2 /* No Explicit Ack */ 1302*4882a593Smuzhiyun #define QOS_ACK_BLOCK_ACK 3 /* Block Ack */ 1303*4882a593Smuzhiyun #define QOS_ACK_SHIFT 5 /* QoS ACK shift */ 1304*4882a593Smuzhiyun #define QOS_ACK_MASK 0x0060 /* QoS ACK mask */ 1305*4882a593Smuzhiyun #define QOS_ACK(qos) (((qos) & QOS_ACK_MASK) >> QOS_ACK_SHIFT) /* QoS ACK */ 1306*4882a593Smuzhiyun 1307*4882a593Smuzhiyun /* A-MSDU flag */ 1308*4882a593Smuzhiyun #define QOS_AMSDU_SHIFT 7 /* AMSDU shift */ 1309*4882a593Smuzhiyun #define QOS_AMSDU_MASK 0x0080 /* AMSDU mask */ 1310*4882a593Smuzhiyun 1311*4882a593Smuzhiyun /* QOS Mesh Flags */ 1312*4882a593Smuzhiyun #define QOS_MESH_CTL_FLAG 0x0100u // Mesh Control Present 1313*4882a593Smuzhiyun #define QOS_MESH_PSL_FLAG 0x0200u // Mesh Power Save Level 1314*4882a593Smuzhiyun #define QOS_MESH_RSPI_FLAG 0x0400u // Mesh RSPI 1315*4882a593Smuzhiyun 1316*4882a593Smuzhiyun /* QOS Mesh Accessor macros */ 1317*4882a593Smuzhiyun #define QOS_MESH_CTL(qos) (((qos) & QOS_MESH_CTL_FLAG) != 0) 1318*4882a593Smuzhiyun #define QOS_MESH_PSL(qos) (((qos) & QOS_MESH_PSL_FLAG) != 0) 1319*4882a593Smuzhiyun #define QOS_MESH_RSPI(qos) (((qos) & QOS_MESH_RSPI_FLAG) != 0) 1320*4882a593Smuzhiyun 1321*4882a593Smuzhiyun /* Management Frames */ 1322*4882a593Smuzhiyun 1323*4882a593Smuzhiyun /* Management Frame Constants */ 1324*4882a593Smuzhiyun 1325*4882a593Smuzhiyun /* Fixed fields */ 1326*4882a593Smuzhiyun #define DOT11_MNG_AUTH_ALGO_LEN 2 /* d11 management auth. algo. length */ 1327*4882a593Smuzhiyun #define DOT11_MNG_AUTH_SEQ_LEN 2 /* d11 management auth. seq. length */ 1328*4882a593Smuzhiyun #define DOT11_MNG_BEACON_INT_LEN 2 /* d11 management beacon interval length */ 1329*4882a593Smuzhiyun #define DOT11_MNG_CAP_LEN 2 /* d11 management cap. length */ 1330*4882a593Smuzhiyun #define DOT11_MNG_AP_ADDR_LEN 6 /* d11 management AP address length */ 1331*4882a593Smuzhiyun #define DOT11_MNG_LISTEN_INT_LEN 2 /* d11 management listen interval length */ 1332*4882a593Smuzhiyun #define DOT11_MNG_REASON_LEN 2 /* d11 management reason length */ 1333*4882a593Smuzhiyun #define DOT11_MNG_AID_LEN 2 /* d11 management AID length */ 1334*4882a593Smuzhiyun #define DOT11_MNG_STATUS_LEN 2 /* d11 management status length */ 1335*4882a593Smuzhiyun #define DOT11_MNG_TIMESTAMP_LEN 8 /* d11 management timestamp length */ 1336*4882a593Smuzhiyun 1337*4882a593Smuzhiyun /* DUR/ID field in assoc resp is 0xc000 | AID */ 1338*4882a593Smuzhiyun #define DOT11_AID_MASK 0x3fff /* d11 AID mask */ 1339*4882a593Smuzhiyun #define DOT11_AID_OCTET_VAL_SHIFT 3u /* AID octet value shift */ 1340*4882a593Smuzhiyun #define DOT11_AID_BIT_POS_IN_OCTET 0x07 /* AID bit position in octet */ 1341*4882a593Smuzhiyun 1342*4882a593Smuzhiyun /* Reason Codes */ 1343*4882a593Smuzhiyun #define DOT11_RC_RESERVED 0 /* d11 RC reserved */ 1344*4882a593Smuzhiyun #define DOT11_RC_UNSPECIFIED 1 /* Unspecified reason */ 1345*4882a593Smuzhiyun #define DOT11_RC_AUTH_INVAL 2 /* Previous authentication no longer valid */ 1346*4882a593Smuzhiyun #define DOT11_RC_DEAUTH_LEAVING 3 /* Deauthenticated because sending station 1347*4882a593Smuzhiyun * is leaving (or has left) IBSS or ESS 1348*4882a593Smuzhiyun */ 1349*4882a593Smuzhiyun #define DOT11_RC_INACTIVITY 4 /* Disassociated due to inactivity */ 1350*4882a593Smuzhiyun #define DOT11_RC_BUSY 5 /* Disassociated because AP is unable to handle 1351*4882a593Smuzhiyun * all currently associated stations 1352*4882a593Smuzhiyun */ 1353*4882a593Smuzhiyun #define DOT11_RC_INVAL_CLASS_2 6 /* Class 2 frame received from 1354*4882a593Smuzhiyun * nonauthenticated station 1355*4882a593Smuzhiyun */ 1356*4882a593Smuzhiyun #define DOT11_RC_INVAL_CLASS_3 7 /* Class 3 frame received from 1357*4882a593Smuzhiyun * nonassociated station 1358*4882a593Smuzhiyun */ 1359*4882a593Smuzhiyun #define DOT11_RC_DISASSOC_LEAVING 8 /* Disassociated because sending station is 1360*4882a593Smuzhiyun * leaving (or has left) BSS 1361*4882a593Smuzhiyun */ 1362*4882a593Smuzhiyun #define DOT11_RC_NOT_AUTH 9 /* Station requesting (re)association is not 1363*4882a593Smuzhiyun * authenticated with responding station 1364*4882a593Smuzhiyun */ 1365*4882a593Smuzhiyun #define DOT11_RC_BAD_PC 10 /* Unacceptable power capability element */ 1366*4882a593Smuzhiyun #define DOT11_RC_BAD_CHANNELS 11 /* Unacceptable supported channels element */ 1367*4882a593Smuzhiyun 1368*4882a593Smuzhiyun /* 12 is unused by STA but could be used by AP/GO */ 1369*4882a593Smuzhiyun #define DOT11_RC_DISASSOC_BTM 12 /* Disassociated due to BSS Transition Magmt */ 1370*4882a593Smuzhiyun 1371*4882a593Smuzhiyun /* 13-23 are WPA/802.11i reason codes defined in wpa.h */ 1372*4882a593Smuzhiyun 1373*4882a593Smuzhiyun /* 32-39 are QSTA specific reasons added in 11e */ 1374*4882a593Smuzhiyun #define DOT11_RC_UNSPECIFIED_QOS 32 /* unspecified QoS-related reason */ 1375*4882a593Smuzhiyun #define DOT11_RC_INSUFFCIENT_BW 33 /* QAP lacks sufficient bandwidth */ 1376*4882a593Smuzhiyun #define DOT11_RC_EXCESSIVE_FRAMES 34 /* excessive number of frames need ack */ 1377*4882a593Smuzhiyun #define DOT11_RC_TX_OUTSIDE_TXOP 35 /* transmitting outside the limits of txop */ 1378*4882a593Smuzhiyun #define DOT11_RC_LEAVING_QBSS 36 /* QSTA is leaving the QBSS (or restting) */ 1379*4882a593Smuzhiyun #define DOT11_RC_BAD_MECHANISM 37 /* does not want to use the mechanism */ 1380*4882a593Smuzhiyun #define DOT11_RC_SETUP_NEEDED 38 /* mechanism needs a setup */ 1381*4882a593Smuzhiyun #define DOT11_RC_TIMEOUT 39 /* timeout */ 1382*4882a593Smuzhiyun 1383*4882a593Smuzhiyun #define DOT11_RC_MESH_PEERING_CANCELLED 52 1384*4882a593Smuzhiyun #define DOT11_RC_MESH_MAX_PEERS 53 1385*4882a593Smuzhiyun #define DOT11_RC_MESH_CONFIG_POLICY_VIOLN 54 1386*4882a593Smuzhiyun #define DOT11_RC_MESH_CLOSE_RECVD 55 1387*4882a593Smuzhiyun #define DOT11_RC_MESH_MAX_RETRIES 56 1388*4882a593Smuzhiyun #define DOT11_RC_MESH_CONFIRM_TIMEOUT 57 1389*4882a593Smuzhiyun #define DOT11_RC_MESH_INVALID_GTK 58 1390*4882a593Smuzhiyun #define DOT11_RC_MESH_INCONSISTENT_PARAMS 59 1391*4882a593Smuzhiyun 1392*4882a593Smuzhiyun #define DOT11_RC_MESH_INVALID_SEC_CAP 60 1393*4882a593Smuzhiyun #define DOT11_RC_MESH_PATHERR_NOPROXYINFO 61 1394*4882a593Smuzhiyun #define DOT11_RC_MESH_PATHERR_NOFWINFO 62 1395*4882a593Smuzhiyun #define DOT11_RC_MESH_PATHERR_DSTUNREACH 63 1396*4882a593Smuzhiyun #define DOT11_RC_MESH_MBSSMAC_EXISTS 64 1397*4882a593Smuzhiyun #define DOT11_RC_MESH_CHANSWITCH_REGREQ 65 1398*4882a593Smuzhiyun #define DOT11_RC_MESH_CHANSWITCH_UNSPEC 66 1399*4882a593Smuzhiyun 1400*4882a593Smuzhiyun #define DOT11_RC_POOR_RSSI_CONDITIONS 71 /* Poor RSSI */ 1401*4882a593Smuzhiyun #define DOT11_RC_MAX 71 /* Reason codes > 71 are reserved */ 1402*4882a593Smuzhiyun 1403*4882a593Smuzhiyun #define DOT11_RC_TDLS_PEER_UNREACH 25 1404*4882a593Smuzhiyun #define DOT11_RC_TDLS_DOWN_UNSPECIFIED 26 1405*4882a593Smuzhiyun 1406*4882a593Smuzhiyun /* Status Codes */ 1407*4882a593Smuzhiyun #define DOT11_SC_SUCCESS 0 /* Successful */ 1408*4882a593Smuzhiyun #define DOT11_SC_FAILURE 1 /* Unspecified failure */ 1409*4882a593Smuzhiyun #define DOT11_SC_TDLS_WAKEUP_SCH_ALT 2 /* TDLS wakeup schedule rejected but alternative */ 1410*4882a593Smuzhiyun /* schedule provided */ 1411*4882a593Smuzhiyun #define DOT11_SC_TDLS_WAKEUP_SCH_REJ 3 /* TDLS wakeup schedule rejected */ 1412*4882a593Smuzhiyun #define DOT11_SC_TDLS_SEC_DISABLED 5 /* TDLS Security disabled */ 1413*4882a593Smuzhiyun #define DOT11_SC_LIFETIME_REJ 6 /* Unacceptable lifetime */ 1414*4882a593Smuzhiyun #define DOT11_SC_NOT_SAME_BSS 7 /* Not in same BSS */ 1415*4882a593Smuzhiyun #define DOT11_SC_CAP_MISMATCH 10 /* Cannot support all requested 1416*4882a593Smuzhiyun * capabilities in the Capability 1417*4882a593Smuzhiyun * Information field 1418*4882a593Smuzhiyun */ 1419*4882a593Smuzhiyun #define DOT11_SC_REASSOC_FAIL 11 /* Reassociation denied due to inability 1420*4882a593Smuzhiyun * to confirm that association exists 1421*4882a593Smuzhiyun */ 1422*4882a593Smuzhiyun #define DOT11_SC_ASSOC_FAIL 12 /* Association denied due to reason 1423*4882a593Smuzhiyun * outside the scope of this standard 1424*4882a593Smuzhiyun */ 1425*4882a593Smuzhiyun #define DOT11_SC_AUTH_MISMATCH 13 /* Responding station does not support 1426*4882a593Smuzhiyun * the specified authentication 1427*4882a593Smuzhiyun * algorithm 1428*4882a593Smuzhiyun */ 1429*4882a593Smuzhiyun #define DOT11_SC_AUTH_SEQ 14 /* Received an Authentication frame 1430*4882a593Smuzhiyun * with authentication transaction 1431*4882a593Smuzhiyun * sequence number out of expected 1432*4882a593Smuzhiyun * sequence 1433*4882a593Smuzhiyun */ 1434*4882a593Smuzhiyun #define DOT11_SC_AUTH_CHALLENGE_FAIL 15 /* Authentication rejected because of 1435*4882a593Smuzhiyun * challenge failure 1436*4882a593Smuzhiyun */ 1437*4882a593Smuzhiyun #define DOT11_SC_AUTH_TIMEOUT 16 /* Authentication rejected due to timeout 1438*4882a593Smuzhiyun * waiting for next frame in sequence 1439*4882a593Smuzhiyun */ 1440*4882a593Smuzhiyun #define DOT11_SC_ASSOC_BUSY_FAIL 17 /* Association denied because AP is 1441*4882a593Smuzhiyun * unable to handle additional 1442*4882a593Smuzhiyun * associated stations 1443*4882a593Smuzhiyun */ 1444*4882a593Smuzhiyun #define DOT11_SC_ASSOC_RATE_MISMATCH 18 /* Association denied due to requesting 1445*4882a593Smuzhiyun * station not supporting all of the 1446*4882a593Smuzhiyun * data rates in the BSSBasicRateSet 1447*4882a593Smuzhiyun * parameter 1448*4882a593Smuzhiyun */ 1449*4882a593Smuzhiyun #define DOT11_SC_ASSOC_SHORT_REQUIRED 19 /* Association denied due to requesting 1450*4882a593Smuzhiyun * station not supporting the Short 1451*4882a593Smuzhiyun * Preamble option 1452*4882a593Smuzhiyun */ 1453*4882a593Smuzhiyun #define DOT11_SC_ASSOC_PBCC_REQUIRED 20 /* Association denied due to requesting 1454*4882a593Smuzhiyun * station not supporting the PBCC 1455*4882a593Smuzhiyun * Modulation option 1456*4882a593Smuzhiyun */ 1457*4882a593Smuzhiyun #define DOT11_SC_ASSOC_AGILITY_REQUIRED 21 /* Association denied due to requesting 1458*4882a593Smuzhiyun * station not supporting the Channel 1459*4882a593Smuzhiyun * Agility option 1460*4882a593Smuzhiyun */ 1461*4882a593Smuzhiyun #define DOT11_SC_ASSOC_SPECTRUM_REQUIRED 22 /* Association denied because Spectrum 1462*4882a593Smuzhiyun * Management capability is required. 1463*4882a593Smuzhiyun */ 1464*4882a593Smuzhiyun #define DOT11_SC_ASSOC_BAD_POWER_CAP 23 /* Association denied because the info 1465*4882a593Smuzhiyun * in the Power Cap element is 1466*4882a593Smuzhiyun * unacceptable. 1467*4882a593Smuzhiyun */ 1468*4882a593Smuzhiyun #define DOT11_SC_ASSOC_BAD_SUP_CHANNELS 24 /* Association denied because the info 1469*4882a593Smuzhiyun * in the Supported Channel element is 1470*4882a593Smuzhiyun * unacceptable 1471*4882a593Smuzhiyun */ 1472*4882a593Smuzhiyun #define DOT11_SC_ASSOC_SHORTSLOT_REQUIRED 25 /* Association denied due to requesting 1473*4882a593Smuzhiyun * station not supporting the Short Slot 1474*4882a593Smuzhiyun * Time option 1475*4882a593Smuzhiyun */ 1476*4882a593Smuzhiyun #define DOT11_SC_ASSOC_DSSSOFDM_REQUIRED 26 /* Association denied because requesting station 1477*4882a593Smuzhiyun * does not support the DSSS-OFDM option 1478*4882a593Smuzhiyun */ 1479*4882a593Smuzhiyun #define DOT11_SC_ASSOC_HT_REQUIRED 27 /* Association denied because the requesting 1480*4882a593Smuzhiyun * station does not support HT features 1481*4882a593Smuzhiyun */ 1482*4882a593Smuzhiyun #define DOT11_SC_ASSOC_R0KH_UNREACHABLE 28 /* Association denied due to AP 1483*4882a593Smuzhiyun * being unable to reach the R0 Key Holder 1484*4882a593Smuzhiyun */ 1485*4882a593Smuzhiyun #define DOT11_SC_ASSOC_TRY_LATER 30 /* Association denied temporarily, try again later 1486*4882a593Smuzhiyun */ 1487*4882a593Smuzhiyun #define DOT11_SC_ASSOC_MFP_VIOLATION 31 /* Association denied due to Robust Management 1488*4882a593Smuzhiyun * frame policy violation 1489*4882a593Smuzhiyun */ 1490*4882a593Smuzhiyun 1491*4882a593Smuzhiyun #define DOT11_SC_POOR_RSSI_CONDN 34 /* Association denied due to poor RSSI */ 1492*4882a593Smuzhiyun #define DOT11_SC_DECLINED 37 /* request declined */ 1493*4882a593Smuzhiyun #define DOT11_SC_INVALID_PARAMS 38 /* One or more params have invalid values */ 1494*4882a593Smuzhiyun #define DOT11_SC_INVALID_PAIRWISE_CIPHER 42 /* invalid pairwise cipher */ 1495*4882a593Smuzhiyun #define DOT11_SC_INVALID_AKMP 43 /* Association denied due to invalid AKMP */ 1496*4882a593Smuzhiyun #define DOT11_SC_INVALID_RSNIE_CAP 45 /* invalid RSN IE capabilities */ 1497*4882a593Smuzhiyun #define DOT11_SC_DLS_NOT_ALLOWED 48 /* DLS is not allowed in the BSS by policy */ 1498*4882a593Smuzhiyun #define DOT11_SC_INVALID_PMKID 53 /* Association denied due to invalid PMKID */ 1499*4882a593Smuzhiyun #define DOT11_SC_INVALID_MDID 54 /* Association denied due to invalid MDID */ 1500*4882a593Smuzhiyun #define DOT11_SC_INVALID_FTIE 55 /* Association denied due to invalid FTIE */ 1501*4882a593Smuzhiyun 1502*4882a593Smuzhiyun #define DOT11_SC_ADV_PROTO_NOT_SUPPORTED 59 /* ad proto not supported */ 1503*4882a593Smuzhiyun #define DOT11_SC_NO_OUTSTAND_REQ 60 /* no outstanding req */ 1504*4882a593Smuzhiyun #define DOT11_SC_RSP_NOT_RX_FROM_SERVER 61 /* no response from server */ 1505*4882a593Smuzhiyun #define DOT11_SC_TIMEOUT 62 /* timeout */ 1506*4882a593Smuzhiyun #define DOT11_SC_QUERY_RSP_TOO_LARGE 63 /* query rsp too large */ 1507*4882a593Smuzhiyun #define DOT11_SC_SERVER_UNREACHABLE 65 /* server unreachable */ 1508*4882a593Smuzhiyun 1509*4882a593Smuzhiyun #define DOT11_SC_UNEXP_MSG 70 /* Unexpected message */ 1510*4882a593Smuzhiyun #define DOT11_SC_INVALID_SNONCE 71 /* Invalid SNonce */ 1511*4882a593Smuzhiyun #define DOT11_SC_INVALID_RSNIE 72 /* Invalid contents of RSNIE */ 1512*4882a593Smuzhiyun 1513*4882a593Smuzhiyun #define DOT11_SC_ANTICLOG_TOCKEN_REQUIRED 76 /* Anti-clogging tocken required */ 1514*4882a593Smuzhiyun #define DOT11_SC_INVALID_FINITE_CYCLIC_GRP 77 /* Invalid contents of RSNIE */ 1515*4882a593Smuzhiyun #define DOT11_SC_TRANSMIT_FAILURE 79 /* transmission failure */ 1516*4882a593Smuzhiyun 1517*4882a593Smuzhiyun #define DOT11_SC_TCLAS_RESOURCES_EXHAUSTED 81u /* TCLAS resources exhausted */ 1518*4882a593Smuzhiyun 1519*4882a593Smuzhiyun #define DOT11_SC_TCLAS_PROCESSING_TERMINATED 97 /* End traffic classification */ 1520*4882a593Smuzhiyun 1521*4882a593Smuzhiyun #define DOT11_SC_ASSOC_VHT_REQUIRED 104 /* Association denied because the requesting 1522*4882a593Smuzhiyun * station does not support VHT features. 1523*4882a593Smuzhiyun */ 1524*4882a593Smuzhiyun #define DOT11_SC_UNKNOWN_PASSWORD_IDENTIFIER 123u /* mismatch of password id */ 1525*4882a593Smuzhiyun 1526*4882a593Smuzhiyun #define DOT11_SC_SAE_HASH_TO_ELEMENT 126u /* SAE Hash-to-element PWE required */ 1527*4882a593Smuzhiyun #define DOT11_SC_SAE_PK 127u /* SAE PK required */ 1528*4882a593Smuzhiyun 1529*4882a593Smuzhiyun /* Requested TCLAS processing has been terminated by the AP due to insufficient QoS capacity. */ 1530*4882a593Smuzhiyun #define DOT11_SC_TCLAS_PROCESSING_TERMINATED_INSUFFICIENT_QOS 128u 1531*4882a593Smuzhiyun 1532*4882a593Smuzhiyun /* Requested TCLAS processing has been terminated by the AP due to conflict with 1533*4882a593Smuzhiyun * higher layer QoS policies. 1534*4882a593Smuzhiyun */ 1535*4882a593Smuzhiyun #define DOT11_SC_TCLAS_PROCESSING_TERMINATED_POLICY_CONFLICT 129u 1536*4882a593Smuzhiyun 1537*4882a593Smuzhiyun /* Info Elts, length of INFORMATION portion of Info Elts */ 1538*4882a593Smuzhiyun #define DOT11_MNG_DS_PARAM_LEN 1 /* d11 management DS parameter length */ 1539*4882a593Smuzhiyun #define DOT11_MNG_IBSS_PARAM_LEN 2 /* d11 management IBSS parameter length */ 1540*4882a593Smuzhiyun 1541*4882a593Smuzhiyun /* TIM Info element has 3 bytes fixed info in INFORMATION field, 1542*4882a593Smuzhiyun * followed by 1 to 251 bytes of Partial Virtual Bitmap 1543*4882a593Smuzhiyun */ 1544*4882a593Smuzhiyun #define DOT11_MNG_TIM_FIXED_LEN 3 /* d11 management TIM fixed length */ 1545*4882a593Smuzhiyun #define DOT11_MNG_TIM_DTIM_COUNT 0 /* d11 management DTIM count */ 1546*4882a593Smuzhiyun #define DOT11_MNG_TIM_DTIM_PERIOD 1 /* d11 management DTIM period */ 1547*4882a593Smuzhiyun #define DOT11_MNG_TIM_BITMAP_CTL 2 /* d11 management TIM BITMAP control */ 1548*4882a593Smuzhiyun #define DOT11_MNG_TIM_PVB 3 /* d11 management TIM PVB */ 1549*4882a593Smuzhiyun 1550*4882a593Smuzhiyun #define DOT11_MNG_TIM_BITMAP_CTL_BCMC_MASK 0x01 /* Mask for bcmc bit in tim bitmap ctrl */ 1551*4882a593Smuzhiyun #define DOT11_MNG_TIM_BITMAP_CTL_PVBOFF_MASK 0xFE /* Mask for partial virtual bitmap */ 1552*4882a593Smuzhiyun 1553*4882a593Smuzhiyun /* TLV defines */ 1554*4882a593Smuzhiyun #define TLV_TAG_OFF 0 /* tag offset */ 1555*4882a593Smuzhiyun #define TLV_LEN_OFF 1 /* length offset */ 1556*4882a593Smuzhiyun #define TLV_HDR_LEN 2 /* header length */ 1557*4882a593Smuzhiyun #define TLV_BODY_OFF 2 /* body offset */ 1558*4882a593Smuzhiyun #define TLV_BODY_LEN_MAX 255 /* max body length */ 1559*4882a593Smuzhiyun #define TLV_EXT_HDR_LEN 3u /* extended IE header length */ 1560*4882a593Smuzhiyun #define TLV_EXT_BODY_OFF 3u /* extended IE body offset */ 1561*4882a593Smuzhiyun 1562*4882a593Smuzhiyun /* Management Frame Information Element IDs */ 1563*4882a593Smuzhiyun enum dot11_tag_ids { 1564*4882a593Smuzhiyun DOT11_MNG_SSID_ID = 0, /* d11 management SSID id */ 1565*4882a593Smuzhiyun DOT11_MNG_RATES_ID = 1, /* d11 management rates id */ 1566*4882a593Smuzhiyun DOT11_MNG_FH_PARMS_ID = 2, /* d11 management FH parameter id */ 1567*4882a593Smuzhiyun DOT11_MNG_DS_PARMS_ID = 3, /* d11 management DS parameter id */ 1568*4882a593Smuzhiyun DOT11_MNG_CF_PARMS_ID = 4, /* d11 management CF parameter id */ 1569*4882a593Smuzhiyun DOT11_MNG_TIM_ID = 5, /* d11 management TIM id */ 1570*4882a593Smuzhiyun DOT11_MNG_IBSS_PARMS_ID = 6, /* d11 management IBSS parameter id */ 1571*4882a593Smuzhiyun DOT11_MNG_COUNTRY_ID = 7, /* d11 management country id */ 1572*4882a593Smuzhiyun DOT11_MNG_HOPPING_PARMS_ID = 8, /* d11 management hopping parameter id */ 1573*4882a593Smuzhiyun DOT11_MNG_HOPPING_TABLE_ID = 9, /* d11 management hopping table id */ 1574*4882a593Smuzhiyun DOT11_MNG_FTM_SYNC_INFO_ID = 9, /* 11mc D4.3 */ 1575*4882a593Smuzhiyun DOT11_MNG_REQUEST_ID = 10, /* d11 management request id */ 1576*4882a593Smuzhiyun DOT11_MNG_QBSS_LOAD_ID = 11, /* d11 management QBSS Load id */ 1577*4882a593Smuzhiyun DOT11_MNG_EDCA_PARAM_ID = 12, /* 11E EDCA Parameter id */ 1578*4882a593Smuzhiyun DOT11_MNG_TSPEC_ID = 13, /* d11 management TSPEC id */ 1579*4882a593Smuzhiyun DOT11_MNG_TCLAS_ID = 14, /* d11 management TCLAS id */ 1580*4882a593Smuzhiyun DOT11_MNG_CHALLENGE_ID = 16, /* d11 management chanllenge id */ 1581*4882a593Smuzhiyun DOT11_MNG_PWR_CONSTRAINT_ID = 32, /* 11H PowerConstraint */ 1582*4882a593Smuzhiyun DOT11_MNG_PWR_CAP_ID = 33, /* 11H PowerCapability */ 1583*4882a593Smuzhiyun DOT11_MNG_TPC_REQUEST_ID = 34, /* 11H TPC Request */ 1584*4882a593Smuzhiyun DOT11_MNG_TPC_REPORT_ID = 35, /* 11H TPC Report */ 1585*4882a593Smuzhiyun DOT11_MNG_SUPP_CHANNELS_ID = 36, /* 11H Supported Channels */ 1586*4882a593Smuzhiyun DOT11_MNG_CHANNEL_SWITCH_ID = 37, /* 11H ChannelSwitch Announcement */ 1587*4882a593Smuzhiyun DOT11_MNG_MEASURE_REQUEST_ID = 38, /* 11H MeasurementRequest */ 1588*4882a593Smuzhiyun DOT11_MNG_MEASURE_REPORT_ID = 39, /* 11H MeasurementReport */ 1589*4882a593Smuzhiyun DOT11_MNG_QUIET_ID = 40, /* 11H Quiet */ 1590*4882a593Smuzhiyun DOT11_MNG_IBSS_DFS_ID = 41, /* 11H IBSS_DFS */ 1591*4882a593Smuzhiyun DOT11_MNG_ERP_ID = 42, /* d11 management ERP id */ 1592*4882a593Smuzhiyun DOT11_MNG_TS_DELAY_ID = 43, /* d11 management TS Delay id */ 1593*4882a593Smuzhiyun DOT11_MNG_TCLAS_PROC_ID = 44, /* d11 management TCLAS processing id */ 1594*4882a593Smuzhiyun DOT11_MNG_HT_CAP = 45, /* d11 mgmt HT cap id */ 1595*4882a593Smuzhiyun DOT11_MNG_QOS_CAP_ID = 46, /* 11E QoS Capability id */ 1596*4882a593Smuzhiyun DOT11_MNG_NONERP_ID = 47, /* d11 management NON-ERP id */ 1597*4882a593Smuzhiyun DOT11_MNG_RSN_ID = 48, /* d11 management RSN id */ 1598*4882a593Smuzhiyun DOT11_MNG_EXT_RATES_ID = 50, /* d11 management ext. rates id */ 1599*4882a593Smuzhiyun DOT11_MNG_AP_CHREP_ID = 51, /* 11k AP Channel report id */ 1600*4882a593Smuzhiyun DOT11_MNG_NEIGHBOR_REP_ID = 52, /* 11k & 11v Neighbor report id */ 1601*4882a593Smuzhiyun DOT11_MNG_RCPI_ID = 53, /* 11k RCPI */ 1602*4882a593Smuzhiyun DOT11_MNG_MDIE_ID = 54, /* 11r Mobility domain id */ 1603*4882a593Smuzhiyun DOT11_MNG_FTIE_ID = 55, /* 11r Fast Bss Transition id */ 1604*4882a593Smuzhiyun DOT11_MNG_FT_TI_ID = 56, /* 11r Timeout Interval id */ 1605*4882a593Smuzhiyun DOT11_MNG_RDE_ID = 57, /* 11r RIC Data Element id */ 1606*4882a593Smuzhiyun DOT11_MNG_REGCLASS_ID = 59, /* d11 management regulatory class id */ 1607*4882a593Smuzhiyun DOT11_MNG_EXT_CSA_ID = 60, /* d11 Extended CSA */ 1608*4882a593Smuzhiyun DOT11_MNG_HT_ADD = 61, /* d11 mgmt additional HT info */ 1609*4882a593Smuzhiyun DOT11_MNG_EXT_CHANNEL_OFFSET = 62, /* d11 mgmt ext channel offset */ 1610*4882a593Smuzhiyun DOT11_MNG_BSS_AVR_ACCESS_DELAY_ID = 63, /* 11k bss average access delay */ 1611*4882a593Smuzhiyun DOT11_MNG_ANTENNA_ID = 64, /* 11k antenna id */ 1612*4882a593Smuzhiyun DOT11_MNG_RSNI_ID = 65, /* 11k RSNI id */ 1613*4882a593Smuzhiyun DOT11_MNG_MEASUREMENT_PILOT_TX_ID = 66, /* 11k measurement pilot tx info id */ 1614*4882a593Smuzhiyun DOT11_MNG_BSS_AVAL_ADMISSION_CAP_ID = 67, /* 11k bss aval admission cap id */ 1615*4882a593Smuzhiyun DOT11_MNG_BSS_AC_ACCESS_DELAY_ID = 68, /* 11k bss AC access delay id */ 1616*4882a593Smuzhiyun DOT11_MNG_WAPI_ID = 68, /* d11 management WAPI id */ 1617*4882a593Smuzhiyun DOT11_MNG_TIME_ADVERTISE_ID = 69, /* 11p time advertisement */ 1618*4882a593Smuzhiyun DOT11_MNG_RRM_CAP_ID = 70, /* 11k radio measurement capability */ 1619*4882a593Smuzhiyun DOT11_MNG_MULTIPLE_BSSID_ID = 71, /* 11k multiple BSSID id */ 1620*4882a593Smuzhiyun DOT11_MNG_HT_BSS_COEXINFO_ID = 72, /* d11 mgmt OBSS Coexistence INFO */ 1621*4882a593Smuzhiyun DOT11_MNG_HT_BSS_CHANNEL_REPORT_ID = 73, /* d11 mgmt OBSS Intolerant Channel list */ 1622*4882a593Smuzhiyun DOT11_MNG_HT_OBSS_ID = 74, /* d11 mgmt OBSS HT info */ 1623*4882a593Smuzhiyun DOT11_MNG_MMIE_ID = 76, /* d11 mgmt MIC IE */ 1624*4882a593Smuzhiyun DOT11_MNG_NONTRANS_BSSID_CAP_ID = 83, /* 11k nontransmitted BSSID capability */ 1625*4882a593Smuzhiyun DOT11_MNG_MULTIPLE_BSSIDINDEX_ID = 85, /* 11k multiple BSSID index */ 1626*4882a593Smuzhiyun DOT11_MNG_FMS_DESCR_ID = 86, /* 11v FMS descriptor */ 1627*4882a593Smuzhiyun DOT11_MNG_FMS_REQ_ID = 87, /* 11v FMS request id */ 1628*4882a593Smuzhiyun DOT11_MNG_FMS_RESP_ID = 88, /* 11v FMS response id */ 1629*4882a593Smuzhiyun DOT11_MNG_BSS_MAX_IDLE_PERIOD_ID = 90, /* 11v bss max idle id */ 1630*4882a593Smuzhiyun DOT11_MNG_TFS_REQUEST_ID = 91, /* 11v tfs request id */ 1631*4882a593Smuzhiyun DOT11_MNG_TFS_RESPONSE_ID = 92, /* 11v tfs response id */ 1632*4882a593Smuzhiyun DOT11_MNG_WNM_SLEEP_MODE_ID = 93, /* 11v wnm-sleep mode id */ 1633*4882a593Smuzhiyun DOT11_MNG_TIMBC_REQ_ID = 94, /* 11v TIM broadcast request id */ 1634*4882a593Smuzhiyun DOT11_MNG_TIMBC_RESP_ID = 95, /* 11v TIM broadcast response id */ 1635*4882a593Smuzhiyun DOT11_MNG_CHANNEL_USAGE = 97, /* 11v channel usage */ 1636*4882a593Smuzhiyun DOT11_MNG_TIME_ZONE_ID = 98, /* 11v time zone */ 1637*4882a593Smuzhiyun DOT11_MNG_DMS_REQUEST_ID = 99, /* 11v dms request id */ 1638*4882a593Smuzhiyun DOT11_MNG_DMS_RESPONSE_ID = 100, /* 11v dms response id */ 1639*4882a593Smuzhiyun DOT11_MNG_LINK_IDENTIFIER_ID = 101, /* 11z TDLS Link Identifier IE */ 1640*4882a593Smuzhiyun DOT11_MNG_WAKEUP_SCHEDULE_ID = 102, /* 11z TDLS Wakeup Schedule IE */ 1641*4882a593Smuzhiyun DOT11_MNG_CHANNEL_SWITCH_TIMING_ID = 104, /* 11z TDLS Channel Switch Timing IE */ 1642*4882a593Smuzhiyun DOT11_MNG_PTI_CONTROL_ID = 105, /* 11z TDLS PTI Control IE */ 1643*4882a593Smuzhiyun DOT11_MNG_PU_BUFFER_STATUS_ID = 106, /* 11z TDLS PU Buffer Status IE */ 1644*4882a593Smuzhiyun DOT11_MNG_INTERWORKING_ID = 107, /* 11u interworking */ 1645*4882a593Smuzhiyun DOT11_MNG_ADVERTISEMENT_ID = 108, /* 11u advertisement protocol */ 1646*4882a593Smuzhiyun DOT11_MNG_EXP_BW_REQ_ID = 109, /* 11u expedited bandwith request */ 1647*4882a593Smuzhiyun DOT11_MNG_QOS_MAP_ID = 110, /* 11u QoS map set */ 1648*4882a593Smuzhiyun DOT11_MNG_ROAM_CONSORT_ID = 111, /* 11u roaming consortium */ 1649*4882a593Smuzhiyun DOT11_MNG_EMERGCY_ALERT_ID = 112, /* 11u emergency alert identifier */ 1650*4882a593Smuzhiyun DOT11_MNG_MESH_CONFIG = 113, /* Mesh Configuration */ 1651*4882a593Smuzhiyun DOT11_MNG_MESH_ID = 114, /* Mesh ID */ 1652*4882a593Smuzhiyun DOT11_MNG_MESH_PEER_MGMT_ID = 117, /* Mesh PEER MGMT IE */ 1653*4882a593Smuzhiyun DOT11_MNG_EXT_CAP_ID = 127, /* d11 mgmt ext capability */ 1654*4882a593Smuzhiyun DOT11_MNG_EXT_PREQ_ID = 130, /* Mesh PREQ IE */ 1655*4882a593Smuzhiyun DOT11_MNG_EXT_PREP_ID = 131, /* Mesh PREP IE */ 1656*4882a593Smuzhiyun DOT11_MNG_EXT_PERR_ID = 132, /* Mesh PERR IE */ 1657*4882a593Smuzhiyun DOT11_MNG_VHT_CAP_ID = 191, /* d11 mgmt VHT cap id */ 1658*4882a593Smuzhiyun DOT11_MNG_VHT_OPERATION_ID = 192, /* d11 mgmt VHT op id */ 1659*4882a593Smuzhiyun DOT11_MNG_EXT_BSSLOAD_ID = 193, /* d11 mgmt VHT extended bss load id */ 1660*4882a593Smuzhiyun DOT11_MNG_WIDE_BW_CHANNEL_SWITCH_ID = 194, /* Wide BW Channel Switch IE */ 1661*4882a593Smuzhiyun DOT11_MNG_VHT_TRANSMIT_POWER_ENVELOPE_ID= 195, /* VHT transmit Power Envelope IE */ 1662*4882a593Smuzhiyun DOT11_MNG_CHANNEL_SWITCH_WRAPPER_ID = 196, /* Channel Switch Wrapper IE */ 1663*4882a593Smuzhiyun DOT11_MNG_AID_ID = 197, /* Association ID IE */ 1664*4882a593Smuzhiyun DOT11_MNG_OPER_MODE_NOTIF_ID = 199, /* d11 mgmt VHT oper mode notif */ 1665*4882a593Smuzhiyun DOT11_MNG_RNR_ID = 201, 1666*4882a593Smuzhiyun /* FIXME: Use these temp. IDs until ANA assigns IDs */ 1667*4882a593Smuzhiyun DOT11_MNG_FTM_PARAMS_ID = 206, /* mcd3.2/2014 this is not final yet */ 1668*4882a593Smuzhiyun DOT11_MNG_TWT_ID = 216, /* 11ah D5.0 */ 1669*4882a593Smuzhiyun DOT11_MNG_WPA_ID = 221, /* d11 management WPA id */ 1670*4882a593Smuzhiyun DOT11_MNG_PROPR_ID = 221, /* d11 management proprietary id */ 1671*4882a593Smuzhiyun /* should start using this one instead of above two */ 1672*4882a593Smuzhiyun DOT11_MNG_VS_ID = 221, /* d11 management Vendor Specific IE */ 1673*4882a593Smuzhiyun DOT11_MNG_MESH_CSP_ID = 222, /* d11 Mesh Channel Switch Parameter */ 1674*4882a593Smuzhiyun DOT11_MNG_FILS_IND_ID = 240, /* 11ai FILS Indication element */ 1675*4882a593Smuzhiyun DOT11_MNG_FRAGMENT_ID = 242, /* IE's fragment ID */ 1676*4882a593Smuzhiyun DOT11_MNG_RSNXE_ID = 244, /* RSN Extension Element (RSNXE) ID */ 1677*4882a593Smuzhiyun 1678*4882a593Smuzhiyun /* The follwing ID extensions should be defined >= 255 1679*4882a593Smuzhiyun * i.e. the values should include 255 (DOT11_MNG_ID_EXT_ID + ID Extension). 1680*4882a593Smuzhiyun */ 1681*4882a593Smuzhiyun DOT11_MNG_ID_EXT_ID = 255 /* Element ID Extension 11mc D4.3 */ 1682*4882a593Smuzhiyun }; 1683*4882a593Smuzhiyun 1684*4882a593Smuzhiyun /* FILS and OCE ext ids */ 1685*4882a593Smuzhiyun #define FILS_EXTID_MNG_REQ_PARAMS 2u /* FILS Request Parameters element */ 1686*4882a593Smuzhiyun #define DOT11_MNG_FILS_REQ_PARAMS (DOT11_MNG_ID_EXT_ID + FILS_EXTID_MNG_REQ_PARAMS) 1687*4882a593Smuzhiyun #define FILS_EXTID_MNG_KEY_CONFIRMATION_ID 3u /* FILS Key Confirmation element */ 1688*4882a593Smuzhiyun #define DOT11_MNG_FILS_KEY_CONFIRMATION (DOT11_MNG_ID_EXT_ID + \ 1689*4882a593Smuzhiyun FILS_EXTID_MNG_KEY_CONFIRMATION_ID) 1690*4882a593Smuzhiyun #define FILS_EXTID_MNG_SESSION_ID 4u /* FILS Session element */ 1691*4882a593Smuzhiyun #define DOT11_MNG_FILS_SESSION (DOT11_MNG_ID_EXT_ID + FILS_EXTID_MNG_SESSION_ID) 1692*4882a593Smuzhiyun #define FILS_EXTID_MNG_HLP_CONTAINER_ID 5u /* FILS HLP Container element */ 1693*4882a593Smuzhiyun #define DOT11_MNG_FILS_HLP_CONTAINER (DOT11_MNG_ID_EXT_ID + \ 1694*4882a593Smuzhiyun FILS_EXTID_MNG_HLP_CONTAINER_ID) 1695*4882a593Smuzhiyun #define FILS_EXTID_MNG_KEY_DELIVERY_ID 7u /* FILS Key Delivery element */ 1696*4882a593Smuzhiyun #define DOT11_MNG_FILS_KEY_DELIVERY (DOT11_MNG_ID_EXT_ID + \ 1697*4882a593Smuzhiyun FILS_EXTID_MNG_KEY_DELIVERY_ID) 1698*4882a593Smuzhiyun #define FILS_EXTID_MNG_WRAPPED_DATA_ID 8u /* FILS Wrapped Data element */ 1699*4882a593Smuzhiyun #define DOT11_MNG_FILS_WRAPPED_DATA (DOT11_MNG_ID_EXT_ID + \ 1700*4882a593Smuzhiyun FILS_EXTID_MNG_WRAPPED_DATA_ID) 1701*4882a593Smuzhiyun 1702*4882a593Smuzhiyun #define OCE_EXTID_MNG_ESP_ID 11u /* Estimated Service Parameters element */ 1703*4882a593Smuzhiyun #define DOT11_MNG_ESP (DOT11_MNG_ID_EXT_ID + OCE_EXTID_MNG_ESP_ID) 1704*4882a593Smuzhiyun #define FILS_EXTID_MNG_PUBLIC_KEY_ID 12u /* FILS Public Key element */ 1705*4882a593Smuzhiyun #define DOT11_MNG_FILS_PUBLIC_KEY (DOT11_MNG_ID_EXT_ID + FILS_EXTID_MNG_PUBLIC_KEY_ID) 1706*4882a593Smuzhiyun #define FILS_EXTID_MNG_NONCE_ID 13u /* FILS Nonce element */ 1707*4882a593Smuzhiyun #define DOT11_MNG_FILS_NONCE (DOT11_MNG_ID_EXT_ID + FILS_EXTID_MNG_NONCE_ID) 1708*4882a593Smuzhiyun 1709*4882a593Smuzhiyun #define EXT_MNG_OWE_DH_PARAM_ID 32u /* OWE DH Param ID - RFC 8110 */ 1710*4882a593Smuzhiyun #define DOT11_MNG_OWE_DH_PARAM_ID (DOT11_MNG_ID_EXT_ID + EXT_MNG_OWE_DH_PARAM_ID) 1711*4882a593Smuzhiyun #define EXT_MSG_PASSWORD_IDENTIFIER_ID 33u /* Password ID EID */ 1712*4882a593Smuzhiyun #define DOT11_MSG_PASSWORD_IDENTIFIER_ID (DOT11_MNG_ID_EXT_ID + \ 1713*4882a593Smuzhiyun EXT_MSG_PASSWORD_IDENTIFIER_ID) 1714*4882a593Smuzhiyun #define EXT_MNG_HE_CAP_ID 35u /* HE Capabilities, 11ax */ 1715*4882a593Smuzhiyun #define DOT11_MNG_HE_CAP_ID (DOT11_MNG_ID_EXT_ID + EXT_MNG_HE_CAP_ID) 1716*4882a593Smuzhiyun #define EXT_MNG_HE_OP_ID 36u /* HE Operation IE, 11ax */ 1717*4882a593Smuzhiyun #define DOT11_MNG_HE_OP_ID (DOT11_MNG_ID_EXT_ID + EXT_MNG_HE_OP_ID) 1718*4882a593Smuzhiyun #define EXT_MNG_UORA_ID 37u /* UORA Parameter Set */ 1719*4882a593Smuzhiyun #define DOT11_MNG_UORA_ID (DOT11_MNG_ID_EXT_ID + EXT_MNG_UORA_ID) 1720*4882a593Smuzhiyun #define EXT_MNG_MU_EDCA_ID 38u /* MU EDCA Parameter Set */ 1721*4882a593Smuzhiyun #define DOT11_MNG_MU_EDCA_ID (DOT11_MNG_ID_EXT_ID + EXT_MNG_MU_EDCA_ID) 1722*4882a593Smuzhiyun #define EXT_MNG_SRPS_ID 39u /* Spatial Reuse Parameter Set */ 1723*4882a593Smuzhiyun #define DOT11_MNG_SRPS_ID (DOT11_MNG_ID_EXT_ID + EXT_MNG_SRPS_ID) 1724*4882a593Smuzhiyun #define EXT_MNG_BSSCOLOR_CHANGE_ID 42u /* BSS Color Change Announcement */ 1725*4882a593Smuzhiyun #define DOT11_MNG_BSSCOLOR_CHANGE_ID (DOT11_MNG_ID_EXT_ID + EXT_MNG_BSSCOLOR_CHANGE_ID) 1726*4882a593Smuzhiyun #define OCV_EXTID_MNG_OCI_ID 54u /* OCI element */ 1727*4882a593Smuzhiyun #define DOT11_MNG_OCI_ID (DOT11_MNG_ID_EXT_ID + OCV_EXT_OCI_ID) 1728*4882a593Smuzhiyun #define EXT_MNG_SHORT_SSID_ID 58u /* SHORT SSID ELEMENT */ 1729*4882a593Smuzhiyun #define DOT11_MNG_SHORT_SSID_LIST_ID (DOT11_MNG_ID_EXT_ID + EXT_MNG_SHORT_SSID_ID) 1730*4882a593Smuzhiyun #define EXT_MNG_HE_6G_CAP_ID 59u /* HE Extended Capabilities, 11ax */ 1731*4882a593Smuzhiyun #define DOT11_MNG_HE_6G_CAP_ID (DOT11_MNG_ID_EXT_ID + EXT_MNG_HE_6G_CAP_ID) 1732*4882a593Smuzhiyun 1733*4882a593Smuzhiyun #define MSCS_EXTID_MNG_DESCR_ID 88u /* Ext ID for the MSCS descriptor */ 1734*4882a593Smuzhiyun #define DOT11_MNG_MSCS_DESCR_ID (DOT11_MNG_ID_EXT_ID + MSCS_EXTID_MNG_DESCR_ID) 1735*4882a593Smuzhiyun 1736*4882a593Smuzhiyun #define TCLAS_EXTID_MNG_MASK_ID 89u /* Ext ID for the TCLAS Mask element */ 1737*4882a593Smuzhiyun #define DOT11_MNG_TCLASS_MASK_ID (DOT11_MNG_ID_EXT_ID + TCLAS_EXTID_MNG_MASK_ID) 1738*4882a593Smuzhiyun 1739*4882a593Smuzhiyun #define SAE_EXT_REJECTED_GROUPS_ID 92u /* SAE Rejected Groups element */ 1740*4882a593Smuzhiyun #define DOT11_MNG_REJECTED_GROUPS_ID (DOT11_MNG_ID_EXT_ID + SAE_EXT_REJECTED_GROUPS_ID) 1741*4882a593Smuzhiyun #define SAE_EXT_ANTICLOG_TOKEN_CONTAINER_ID 93u /* SAE Anti-clogging token container */ 1742*4882a593Smuzhiyun #define DOT11_MNG_ANTICLOG_TOKEN_CONTAINER_ID (DOT11_MNG_ID_EXT_ID + \ 1743*4882a593Smuzhiyun SAE_EXT_ANTICLOG_TOKEN_CONTAINER_ID) 1744*4882a593Smuzhiyun #define EXT_MNG_EHT_CAP_ID 100u /* EHT Capabilities IE FIXME */ 1745*4882a593Smuzhiyun #define DOT11_MNG_EHT_CAP_ID (DOT11_MNG_ID_EXT_ID + EXT_MNG_EHT_CAP_ID) 1746*4882a593Smuzhiyun #define EXT_MNG_EHT_OP_ID 101u /* EHT Operation IE # FIXME */ 1747*4882a593Smuzhiyun #define DOT11_MNG_EHT_OP_ID (DOT11_MNG_ID_EXT_ID + EXT_MNG_EHT_OP_ID) 1748*4882a593Smuzhiyun 1749*4882a593Smuzhiyun /* unassigned IDs for ranging parameter elements. To be updated after final 1750*4882a593Smuzhiyun * assignement. 1751*4882a593Smuzhiyun */ 1752*4882a593Smuzhiyun #define DOT11_MNG_FTM_RANGING_EXT_ID 100u /* 11AZ sounding mode parameter element */ 1753*4882a593Smuzhiyun #define DOT11_MNG_FTM_ISTA_AVAIL_EXT_ID 101u /* 11 AZ TN ISTA avaialability window */ 1754*4882a593Smuzhiyun #define DOT11_MNG_FTM_RSTA_AVAIL_EXT_ID 102u /* 11 AZ TN RSTA avaialability window */ 1755*4882a593Smuzhiyun #define DOT11_MNG_FTM_SECURE_LTF_EXT_ID 103u /* 11 AZ Secure LTF parameter element */ 1756*4882a593Smuzhiyun 1757*4882a593Smuzhiyun #define DOT11_FTM_NTB_SUB_ELT_ID 0u /* non-TB ranging parameter sub-element ID */ 1758*4882a593Smuzhiyun #define DOT11_FTM_TB_SUB_ELT_ID 1u /* TB ranging parameter sub-element ID */ 1759*4882a593Smuzhiyun 1760*4882a593Smuzhiyun /* deprecated definitions, do not use, to be deleted later */ 1761*4882a593Smuzhiyun #define FILS_HLP_CONTAINER_EXT_ID FILS_EXTID_MNG_HLP_CONTAINER_ID 1762*4882a593Smuzhiyun #define DOT11_ESP_EXT_ID OCE_EXTID_MNG_ESP_ID 1763*4882a593Smuzhiyun #define FILS_REQ_PARAMS_EXT_ID FILS_EXTID_MNG_REQ_PARAMS 1764*4882a593Smuzhiyun #define EXT_MNG_RAPS_ID 37u /* OFDMA Random Access Parameter Set */ 1765*4882a593Smuzhiyun #define DOT11_MNG_RAPS_ID (DOT11_MNG_ID_EXT_ID + EXT_MNG_RAPS_ID) 1766*4882a593Smuzhiyun /* End of deprecated definitions */ 1767*4882a593Smuzhiyun 1768*4882a593Smuzhiyun #define DOT11_MNG_IE_ID_EXT_MATCH(_ie, _id) (\ 1769*4882a593Smuzhiyun ((_ie)->id == DOT11_MNG_ID_EXT_ID) && \ 1770*4882a593Smuzhiyun ((_ie)->len > 0) && \ 1771*4882a593Smuzhiyun ((_id) == ((uint8 *)(_ie) + TLV_HDR_LEN)[0])) 1772*4882a593Smuzhiyun 1773*4882a593Smuzhiyun #define DOT11_MNG_IE_ID_EXT_INIT(_ie, _id, _len) do {\ 1774*4882a593Smuzhiyun (_ie)->id = DOT11_MNG_ID_EXT_ID; \ 1775*4882a593Smuzhiyun (_ie)->len = _len; \ 1776*4882a593Smuzhiyun (_ie)->id_ext = _id; \ 1777*4882a593Smuzhiyun } while (0) 1778*4882a593Smuzhiyun 1779*4882a593Smuzhiyun /* Rate Defines */ 1780*4882a593Smuzhiyun 1781*4882a593Smuzhiyun /* Valid rates for the Supported Rates and Extended Supported Rates IEs. 1782*4882a593Smuzhiyun * Encoding is the rate in 500kbps units, rouding up for fractional values. 1783*4882a593Smuzhiyun * 802.11-2012, section 6.5.5.2, DATA_RATE parameter enumerates all the values. 1784*4882a593Smuzhiyun * The rate values cover DSSS, HR/DSSS, ERP, and OFDM phy rates. 1785*4882a593Smuzhiyun * The defines below do not cover the rates specific to 10MHz, {3, 4.5, 27}, 1786*4882a593Smuzhiyun * and 5MHz, {1.5, 2.25, 3, 4.5, 13.5}, which are not supported by Broadcom devices. 1787*4882a593Smuzhiyun */ 1788*4882a593Smuzhiyun 1789*4882a593Smuzhiyun #define DOT11_RATE_1M 2 /* 1 Mbps in 500kbps units */ 1790*4882a593Smuzhiyun #define DOT11_RATE_2M 4 /* 2 Mbps in 500kbps units */ 1791*4882a593Smuzhiyun #define DOT11_RATE_5M5 11 /* 5.5 Mbps in 500kbps units */ 1792*4882a593Smuzhiyun #define DOT11_RATE_11M 22 /* 11 Mbps in 500kbps units */ 1793*4882a593Smuzhiyun #define DOT11_RATE_6M 12 /* 6 Mbps in 500kbps units */ 1794*4882a593Smuzhiyun #define DOT11_RATE_9M 18 /* 9 Mbps in 500kbps units */ 1795*4882a593Smuzhiyun #define DOT11_RATE_12M 24 /* 12 Mbps in 500kbps units */ 1796*4882a593Smuzhiyun #define DOT11_RATE_18M 36 /* 18 Mbps in 500kbps units */ 1797*4882a593Smuzhiyun #define DOT11_RATE_24M 48 /* 24 Mbps in 500kbps units */ 1798*4882a593Smuzhiyun #define DOT11_RATE_36M 72 /* 36 Mbps in 500kbps units */ 1799*4882a593Smuzhiyun #define DOT11_RATE_48M 96 /* 48 Mbps in 500kbps units */ 1800*4882a593Smuzhiyun #define DOT11_RATE_54M 108 /* 54 Mbps in 500kbps units */ 1801*4882a593Smuzhiyun #define DOT11_RATE_MAX 108 /* highest rate (54 Mbps) in 500kbps units */ 1802*4882a593Smuzhiyun 1803*4882a593Smuzhiyun /* Supported Rates and Extended Supported Rates IEs 1804*4882a593Smuzhiyun * The supported rates octets are defined a the MSB indicatin a Basic Rate 1805*4882a593Smuzhiyun * and bits 0-6 as the rate value 1806*4882a593Smuzhiyun */ 1807*4882a593Smuzhiyun #define DOT11_RATE_BASIC 0x80 /* flag for a Basic Rate */ 1808*4882a593Smuzhiyun #define DOT11_RATE_MASK 0x7F /* mask for numeric part of rate */ 1809*4882a593Smuzhiyun 1810*4882a593Smuzhiyun /* BSS Membership Selector parameters 1811*4882a593Smuzhiyun * 802.11-2016 (and 802.11ax-D1.1), Sec 9.4.2.3 1812*4882a593Smuzhiyun * These selector values are advertised in Supported Rates and Extended Supported Rates IEs 1813*4882a593Smuzhiyun * in the supported rates list with the Basic rate bit set. 1814*4882a593Smuzhiyun * Constants below include the basic bit. 1815*4882a593Smuzhiyun */ 1816*4882a593Smuzhiyun #define DOT11_BSS_MEMBERSHIP_HT 0xFF /* Basic 0x80 + 127, HT Required to join */ 1817*4882a593Smuzhiyun #define DOT11_BSS_MEMBERSHIP_VHT 0xFE /* Basic 0x80 + 126, VHT Required to join */ 1818*4882a593Smuzhiyun #define DOT11_BSS_MEMBERSHIP_HE 0xFD /* Basic 0x80 + 125, HE Required to join */ 1819*4882a593Smuzhiyun #define DOT11_BSS_SAE_HASH_TO_ELEMENT 123u /* SAE Hash-to-element Required to join */ 1820*4882a593Smuzhiyun 1821*4882a593Smuzhiyun /* ERP info element bit values */ 1822*4882a593Smuzhiyun #define DOT11_MNG_ERP_LEN 1 /* ERP is currently 1 byte long */ 1823*4882a593Smuzhiyun #define DOT11_MNG_NONERP_PRESENT 0x01 /* NonERP (802.11b) STAs are present 1824*4882a593Smuzhiyun *in the BSS 1825*4882a593Smuzhiyun */ 1826*4882a593Smuzhiyun #define DOT11_MNG_USE_PROTECTION 0x02 /* Use protection mechanisms for 1827*4882a593Smuzhiyun *ERP-OFDM frames 1828*4882a593Smuzhiyun */ 1829*4882a593Smuzhiyun #define DOT11_MNG_BARKER_PREAMBLE 0x04 /* Short Preambles: 0 == allowed, 1830*4882a593Smuzhiyun * 1 == not allowed 1831*4882a593Smuzhiyun */ 1832*4882a593Smuzhiyun /* TS Delay element offset & size */ 1833*4882a593Smuzhiyun #define DOT11_MGN_TS_DELAY_LEN 4 /* length of TS DELAY IE */ 1834*4882a593Smuzhiyun #define TS_DELAY_FIELD_SIZE 4 /* TS DELAY field size */ 1835*4882a593Smuzhiyun 1836*4882a593Smuzhiyun /* Capability Information Field */ 1837*4882a593Smuzhiyun #define DOT11_CAP_ESS 0x0001 /* d11 cap. ESS */ 1838*4882a593Smuzhiyun #define DOT11_CAP_IBSS 0x0002 /* d11 cap. IBSS */ 1839*4882a593Smuzhiyun #define DOT11_CAP_POLLABLE 0x0004 /* d11 cap. pollable */ 1840*4882a593Smuzhiyun #define DOT11_CAP_POLL_RQ 0x0008 /* d11 cap. poll request */ 1841*4882a593Smuzhiyun #define DOT11_CAP_PRIVACY 0x0010 /* d11 cap. privacy */ 1842*4882a593Smuzhiyun #define DOT11_CAP_SHORT 0x0020 /* d11 cap. short */ 1843*4882a593Smuzhiyun #define DOT11_CAP_PBCC 0x0040 /* d11 cap. PBCC */ 1844*4882a593Smuzhiyun #define DOT11_CAP_AGILITY 0x0080 /* d11 cap. agility */ 1845*4882a593Smuzhiyun #define DOT11_CAP_SPECTRUM 0x0100 /* d11 cap. spectrum */ 1846*4882a593Smuzhiyun #define DOT11_CAP_QOS 0x0200 /* d11 cap. qos */ 1847*4882a593Smuzhiyun #define DOT11_CAP_SHORTSLOT 0x0400 /* d11 cap. shortslot */ 1848*4882a593Smuzhiyun #define DOT11_CAP_APSD 0x0800 /* d11 cap. apsd */ 1849*4882a593Smuzhiyun #define DOT11_CAP_RRM 0x1000 /* d11 cap. 11k radio measurement */ 1850*4882a593Smuzhiyun #define DOT11_CAP_CCK_OFDM 0x2000 /* d11 cap. CCK/OFDM */ 1851*4882a593Smuzhiyun #define DOT11_CAP_DELAY_BA 0x4000 /* d11 cap. delayed block ack */ 1852*4882a593Smuzhiyun #define DOT11_CAP_IMMEDIATE_BA 0x8000 /* d11 cap. immediate block ack */ 1853*4882a593Smuzhiyun 1854*4882a593Smuzhiyun /* Extended capabilities IE bitfields */ 1855*4882a593Smuzhiyun /* 20/40 BSS Coexistence Management support bit position */ 1856*4882a593Smuzhiyun #define DOT11_EXT_CAP_OBSS_COEX_MGMT 0u 1857*4882a593Smuzhiyun /* Extended Channel Switching support bit position */ 1858*4882a593Smuzhiyun #define DOT11_EXT_CAP_EXT_CHAN_SWITCHING 2u 1859*4882a593Smuzhiyun /* scheduled PSMP support bit position */ 1860*4882a593Smuzhiyun #define DOT11_EXT_CAP_SPSMP 6u 1861*4882a593Smuzhiyun /* Flexible Multicast Service */ 1862*4882a593Smuzhiyun #define DOT11_EXT_CAP_FMS 11u 1863*4882a593Smuzhiyun /* proxy ARP service support bit position */ 1864*4882a593Smuzhiyun #define DOT11_EXT_CAP_PROXY_ARP 12u 1865*4882a593Smuzhiyun /* Civic Location */ 1866*4882a593Smuzhiyun #define DOT11_EXT_CAP_CIVIC_LOC 14u 1867*4882a593Smuzhiyun /* Geospatial Location */ 1868*4882a593Smuzhiyun #define DOT11_EXT_CAP_LCI 15u 1869*4882a593Smuzhiyun /* Traffic Filter Service */ 1870*4882a593Smuzhiyun #define DOT11_EXT_CAP_TFS 16u 1871*4882a593Smuzhiyun /* WNM-Sleep Mode */ 1872*4882a593Smuzhiyun #define DOT11_EXT_CAP_WNM_SLEEP 17u 1873*4882a593Smuzhiyun /* TIM Broadcast service */ 1874*4882a593Smuzhiyun #define DOT11_EXT_CAP_TIMBC 18u 1875*4882a593Smuzhiyun /* BSS Transition Management support bit position */ 1876*4882a593Smuzhiyun #define DOT11_EXT_CAP_BSSTRANS_MGMT 19u 1877*4882a593Smuzhiyun /* Multiple BSSID support position */ 1878*4882a593Smuzhiyun #define DOT11_EXT_CAP_MULTIBSSID 22u 1879*4882a593Smuzhiyun /* Direct Multicast Service */ 1880*4882a593Smuzhiyun #define DOT11_EXT_CAP_DMS 26u 1881*4882a593Smuzhiyun /* Interworking support bit position */ 1882*4882a593Smuzhiyun #define DOT11_EXT_CAP_IW 31u 1883*4882a593Smuzhiyun /* QoS map support bit position */ 1884*4882a593Smuzhiyun #define DOT11_EXT_CAP_QOS_MAP 32u 1885*4882a593Smuzhiyun /* service Interval granularity bit position and mask */ 1886*4882a593Smuzhiyun #define DOT11_EXT_CAP_SI 41u 1887*4882a593Smuzhiyun #define DOT11_EXT_CAP_SI_MASK 0x0E 1888*4882a593Smuzhiyun /* Location Identifier service */ 1889*4882a593Smuzhiyun #define DOT11_EXT_CAP_IDENT_LOC 44u 1890*4882a593Smuzhiyun /* WNM notification */ 1891*4882a593Smuzhiyun #define DOT11_EXT_CAP_WNM_NOTIF 46u 1892*4882a593Smuzhiyun /* Operating mode notification - VHT (11ac D3.0 - 8.4.2.29) */ 1893*4882a593Smuzhiyun #define DOT11_EXT_CAP_OPER_MODE_NOTIF 62u 1894*4882a593Smuzhiyun /* Fine timing measurement - D3.0 */ 1895*4882a593Smuzhiyun #define DOT11_EXT_CAP_FTM_RESPONDER 70u 1896*4882a593Smuzhiyun #define DOT11_EXT_CAP_FTM_INITIATOR 71u /* tentative 11mcd3.0 */ 1897*4882a593Smuzhiyun #define DOT11_EXT_CAP_FILS 72u /* FILS Capability */ 1898*4882a593Smuzhiyun /* TWT support */ 1899*4882a593Smuzhiyun #define DOT11_EXT_CAP_TWT_REQUESTER 77u 1900*4882a593Smuzhiyun #define DOT11_EXT_CAP_TWT_RESPONDER 78u 1901*4882a593Smuzhiyun #define DOT11_EXT_CAP_OBSS_NB_RU_OFDMA 79u 1902*4882a593Smuzhiyun /* FIXME: Use these temp. IDs until ANA assigns IDs */ 1903*4882a593Smuzhiyun #define DOT11_EXT_CAP_EMBSS_ADVERTISE 80u 1904*4882a593Smuzhiyun /* SAE password ID */ 1905*4882a593Smuzhiyun #define DOT11_EXT_CAP_SAE_PWD_ID_INUSE 81u 1906*4882a593Smuzhiyun #define DOT11_EXT_CAP_SAE_PWD_ID_USED_EXCLUSIVE 82u 1907*4882a593Smuzhiyun /* Beacon Protection Enabled 802.11 D3.0 - 9.4.2.26 1908*4882a593Smuzhiyun * This field is reserved for a STA. 1909*4882a593Smuzhiyun */ 1910*4882a593Smuzhiyun #define DOT11_EXT_CAP_BCN_PROT 84u 1911*4882a593Smuzhiyun 1912*4882a593Smuzhiyun /* Mirrored SCS (MSCS) support */ 1913*4882a593Smuzhiyun #define DOT11_EXT_CAP_MSCS 85u 1914*4882a593Smuzhiyun 1915*4882a593Smuzhiyun /* TODO: Update DOT11_EXT_CAP_MAX_IDX to reflect the highest offset. 1916*4882a593Smuzhiyun * Note: DOT11_EXT_CAP_MAX_IDX must only be used in attach path. 1917*4882a593Smuzhiyun * It will cause ROM invalidation otherwise. 1918*4882a593Smuzhiyun */ 1919*4882a593Smuzhiyun #define DOT11_EXT_CAP_MAX_IDX 85u 1920*4882a593Smuzhiyun 1921*4882a593Smuzhiyun /* Remove this hack (DOT11_EXT_CAP_MAX_BIT_IDX) when no one 1922*4882a593Smuzhiyun * references DOT11_EXTCAP_LEN_MAX 1923*4882a593Smuzhiyun */ 1924*4882a593Smuzhiyun #define DOT11_EXT_CAP_MAX_BIT_IDX 95u /* !!!update this please!!! */ 1925*4882a593Smuzhiyun 1926*4882a593Smuzhiyun /* Remove DOT11_EXTCAP_LEN_MAX when no one references it */ 1927*4882a593Smuzhiyun /* extended capability */ 1928*4882a593Smuzhiyun #ifndef DOT11_EXTCAP_LEN_MAX 1929*4882a593Smuzhiyun #define DOT11_EXTCAP_LEN_MAX ((DOT11_EXT_CAP_MAX_BIT_IDX + 8) >> 3) 1930*4882a593Smuzhiyun #endif 1931*4882a593Smuzhiyun /* Remove dot11_extcap when no one references it */ 1932*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_extcap { 1933*4882a593Smuzhiyun uint8 extcap[DOT11_EXTCAP_LEN_MAX]; 1934*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 1935*4882a593Smuzhiyun typedef struct dot11_extcap dot11_extcap_t; 1936*4882a593Smuzhiyun 1937*4882a593Smuzhiyun /* VHT Operating mode bit fields - (11ac D8.0/802.11-2016 - 9.4.1.53) */ 1938*4882a593Smuzhiyun #define DOT11_OPER_MODE_CHANNEL_WIDTH_SHIFT 0 1939*4882a593Smuzhiyun #define DOT11_OPER_MODE_CHANNEL_WIDTH_MASK 0x3 1940*4882a593Smuzhiyun #define DOT11_OPER_MODE_160_8080_BW_SHIFT 2 1941*4882a593Smuzhiyun #define DOT11_OPER_MODE_160_8080_BW_MASK 0x04 1942*4882a593Smuzhiyun #define DOT11_OPER_MODE_NOLDPC_SHIFT 3 1943*4882a593Smuzhiyun #define DOT11_OPER_MODE_NOLDPC_MASK 0x08 1944*4882a593Smuzhiyun #define DOT11_OPER_MODE_RXNSS_SHIFT 4 1945*4882a593Smuzhiyun #define DOT11_OPER_MODE_RXNSS_MASK 0x70 1946*4882a593Smuzhiyun #define DOT11_OPER_MODE_RXNSS_TYPE_SHIFT 7 1947*4882a593Smuzhiyun #define DOT11_OPER_MODE_RXNSS_TYPE_MASK 0x80 1948*4882a593Smuzhiyun 1949*4882a593Smuzhiyun #define DOT11_OPER_MODE_RESET_CHAN_WIDTH_160MHZ(oper_mode) \ 1950*4882a593Smuzhiyun (oper_mode & (~(DOT11_OPER_MODE_CHANNEL_WIDTH_MASK | \ 1951*4882a593Smuzhiyun DOT11_OPER_MODE_160_8080_BW_MASK))) 1952*4882a593Smuzhiyun #define DOT11_OPER_MODE_SET_CHAN_WIDTH_160MHZ(oper_mode) \ 1953*4882a593Smuzhiyun (oper_mode = (DOT11_OPER_MODE_RESET_CHAN_WIDTH_160MHZ(oper_mode) | \ 1954*4882a593Smuzhiyun (DOT11_OPER_MODE_80MHZ | DOT11_OPER_MODE_160_8080_BW_MASK))) 1955*4882a593Smuzhiyun 1956*4882a593Smuzhiyun #ifdef DOT11_OPER_MODE_LEFT_SHIFT_FIX 1957*4882a593Smuzhiyun 1958*4882a593Smuzhiyun #define DOT11_OPER_MODE(type, nss, chanw) (\ 1959*4882a593Smuzhiyun ((type) << DOT11_OPER_MODE_RXNSS_TYPE_SHIFT &\ 1960*4882a593Smuzhiyun DOT11_OPER_MODE_RXNSS_TYPE_MASK) |\ 1961*4882a593Smuzhiyun (((nss) - 1u) << DOT11_OPER_MODE_RXNSS_SHIFT & DOT11_OPER_MODE_RXNSS_MASK) |\ 1962*4882a593Smuzhiyun ((chanw) << DOT11_OPER_MODE_CHANNEL_WIDTH_SHIFT &\ 1963*4882a593Smuzhiyun DOT11_OPER_MODE_CHANNEL_WIDTH_MASK)) 1964*4882a593Smuzhiyun 1965*4882a593Smuzhiyun #define DOT11_D8_OPER_MODE(type, nss, ldpc, bw160_8080, chanw) (\ 1966*4882a593Smuzhiyun ((type) << DOT11_OPER_MODE_RXNSS_TYPE_SHIFT &\ 1967*4882a593Smuzhiyun DOT11_OPER_MODE_RXNSS_TYPE_MASK) |\ 1968*4882a593Smuzhiyun (((nss) - 1u) << DOT11_OPER_MODE_RXNSS_SHIFT & DOT11_OPER_MODE_RXNSS_MASK) |\ 1969*4882a593Smuzhiyun ((ldpc) << DOT11_OPER_MODE_NOLDPC_SHIFT & DOT11_OPER_MODE_NOLDPC_MASK) |\ 1970*4882a593Smuzhiyun ((bw160_8080) << DOT11_OPER_MODE_160_8080_BW_SHIFT &\ 1971*4882a593Smuzhiyun DOT11_OPER_MODE_160_8080_BW_MASK) |\ 1972*4882a593Smuzhiyun ((chanw) << DOT11_OPER_MODE_CHANNEL_WIDTH_SHIFT &\ 1973*4882a593Smuzhiyun DOT11_OPER_MODE_CHANNEL_WIDTH_MASK)) 1974*4882a593Smuzhiyun 1975*4882a593Smuzhiyun #else 1976*4882a593Smuzhiyun 1977*4882a593Smuzhiyun /* avoid invalidation from above fix on release branches, can be removed when older release 1978*4882a593Smuzhiyun * branches no longer use component/proto from trunk 1979*4882a593Smuzhiyun */ 1980*4882a593Smuzhiyun 1981*4882a593Smuzhiyun #define DOT11_OPER_MODE(type, nss, chanw) (\ 1982*4882a593Smuzhiyun ((type) << DOT11_OPER_MODE_RXNSS_TYPE_SHIFT &\ 1983*4882a593Smuzhiyun DOT11_OPER_MODE_RXNSS_TYPE_MASK) |\ 1984*4882a593Smuzhiyun (((nss) - 1) << DOT11_OPER_MODE_RXNSS_SHIFT & DOT11_OPER_MODE_RXNSS_MASK) |\ 1985*4882a593Smuzhiyun ((chanw) << DOT11_OPER_MODE_CHANNEL_WIDTH_SHIFT &\ 1986*4882a593Smuzhiyun DOT11_OPER_MODE_CHANNEL_WIDTH_MASK)) 1987*4882a593Smuzhiyun 1988*4882a593Smuzhiyun #define DOT11_D8_OPER_MODE(type, nss, ldpc, bw160_8080, chanw) (\ 1989*4882a593Smuzhiyun ((type) << DOT11_OPER_MODE_RXNSS_TYPE_SHIFT &\ 1990*4882a593Smuzhiyun DOT11_OPER_MODE_RXNSS_TYPE_MASK) |\ 1991*4882a593Smuzhiyun (((nss) - 1) << DOT11_OPER_MODE_RXNSS_SHIFT & DOT11_OPER_MODE_RXNSS_MASK) |\ 1992*4882a593Smuzhiyun ((ldpc) << DOT11_OPER_MODE_NOLDPC_SHIFT & DOT11_OPER_MODE_NOLDPC_MASK) |\ 1993*4882a593Smuzhiyun ((bw160_8080) << DOT11_OPER_MODE_160_8080_BW_SHIFT &\ 1994*4882a593Smuzhiyun DOT11_OPER_MODE_160_8080_BW_MASK) |\ 1995*4882a593Smuzhiyun ((chanw) << DOT11_OPER_MODE_CHANNEL_WIDTH_SHIFT &\ 1996*4882a593Smuzhiyun DOT11_OPER_MODE_CHANNEL_WIDTH_MASK)) 1997*4882a593Smuzhiyun 1998*4882a593Smuzhiyun #endif /* DOT11_OPER_MODE_LEFT_SHIFT_FIX */ 1999*4882a593Smuzhiyun 2000*4882a593Smuzhiyun #define DOT11_OPER_MODE_CHANNEL_WIDTH(mode) \ 2001*4882a593Smuzhiyun (((mode) & DOT11_OPER_MODE_CHANNEL_WIDTH_MASK)\ 2002*4882a593Smuzhiyun >> DOT11_OPER_MODE_CHANNEL_WIDTH_SHIFT) 2003*4882a593Smuzhiyun #define DOT11_OPER_MODE_160_8080(mode) \ 2004*4882a593Smuzhiyun (((mode) & DOT11_OPER_MODE_160_8080_BW_MASK)\ 2005*4882a593Smuzhiyun >> DOT11_OPER_MODE_160_8080_BW_SHIFT) 2006*4882a593Smuzhiyun #define DOT11_OPER_MODE_NOLDPC(mode) \ 2007*4882a593Smuzhiyun (((mode) & DOT11_OPER_MODE_NOLDPC_MASK)\ 2008*4882a593Smuzhiyun >> DOT11_OPER_MODE_NOLDPC_SHIFT) 2009*4882a593Smuzhiyun #define DOT11_OPER_MODE_RXNSS(mode) \ 2010*4882a593Smuzhiyun ((((mode) & DOT11_OPER_MODE_RXNSS_MASK) \ 2011*4882a593Smuzhiyun >> DOT11_OPER_MODE_RXNSS_SHIFT) + 1) 2012*4882a593Smuzhiyun #define DOT11_OPER_MODE_RXNSS_TYPE(mode) \ 2013*4882a593Smuzhiyun (((mode) & DOT11_OPER_MODE_RXNSS_TYPE_MASK)\ 2014*4882a593Smuzhiyun >> DOT11_OPER_MODE_RXNSS_TYPE_SHIFT) 2015*4882a593Smuzhiyun 2016*4882a593Smuzhiyun #define DOT11_OPER_MODE_20MHZ 0 2017*4882a593Smuzhiyun #define DOT11_OPER_MODE_40MHZ 1 2018*4882a593Smuzhiyun #define DOT11_OPER_MODE_80MHZ 2 2019*4882a593Smuzhiyun #define DOT11_OPER_MODE_160MHZ 3 2020*4882a593Smuzhiyun #define DOT11_OPER_MODE_8080MHZ 3 2021*4882a593Smuzhiyun #define DOT11_OPER_MODE_1608080MHZ 1 2022*4882a593Smuzhiyun 2023*4882a593Smuzhiyun #define DOT11_OPER_MODE_CHANNEL_WIDTH_20MHZ(mode) (\ 2024*4882a593Smuzhiyun ((mode) & DOT11_OPER_MODE_CHANNEL_WIDTH_MASK) == DOT11_OPER_MODE_20MHZ) 2025*4882a593Smuzhiyun #define DOT11_OPER_MODE_CHANNEL_WIDTH_40MHZ(mode) (\ 2026*4882a593Smuzhiyun ((mode) & DOT11_OPER_MODE_CHANNEL_WIDTH_MASK) == DOT11_OPER_MODE_40MHZ) 2027*4882a593Smuzhiyun #define DOT11_OPER_MODE_CHANNEL_WIDTH_80MHZ(mode) (\ 2028*4882a593Smuzhiyun ((mode) & DOT11_OPER_MODE_CHANNEL_WIDTH_MASK) == DOT11_OPER_MODE_80MHZ) 2029*4882a593Smuzhiyun #define DOT11_OPER_MODE_CHANNEL_WIDTH_160MHZ(mode) (\ 2030*4882a593Smuzhiyun ((mode) & DOT11_OPER_MODE_160_8080_BW_MASK)) 2031*4882a593Smuzhiyun #define DOT11_OPER_MODE_CHANNEL_WIDTH_8080MHZ(mode) (\ 2032*4882a593Smuzhiyun ((mode) & DOT11_OPER_MODE_160_8080_BW_MASK)) 2033*4882a593Smuzhiyun 2034*4882a593Smuzhiyun /* Operating mode information element 802.11ac D3.0 - 8.4.2.168 */ 2035*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_oper_mode_notif_ie { 2036*4882a593Smuzhiyun uint8 mode; 2037*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2038*4882a593Smuzhiyun typedef struct dot11_oper_mode_notif_ie dot11_oper_mode_notif_ie_t; 2039*4882a593Smuzhiyun 2040*4882a593Smuzhiyun #define DOT11_OPER_MODE_NOTIF_IE_LEN 1 2041*4882a593Smuzhiyun 2042*4882a593Smuzhiyun /* Extended Capability Information Field */ 2043*4882a593Smuzhiyun #define DOT11_OBSS_COEX_MNG_SUPPORT 0x01 /* 20/40 BSS Coexistence Management support */ 2044*4882a593Smuzhiyun 2045*4882a593Smuzhiyun /* 2046*4882a593Smuzhiyun * Action Frame Constants 2047*4882a593Smuzhiyun */ 2048*4882a593Smuzhiyun #define DOT11_ACTION_HDR_LEN 2 /* action frame category + action field */ 2049*4882a593Smuzhiyun #define DOT11_ACTION_CAT_OFF 0 /* category offset */ 2050*4882a593Smuzhiyun #define DOT11_ACTION_ACT_OFF 1 /* action offset */ 2051*4882a593Smuzhiyun 2052*4882a593Smuzhiyun /* Action Category field (sec 8.4.1.11) */ 2053*4882a593Smuzhiyun #define DOT11_ACTION_CAT_ERR_MASK 0x80 /* category error mask */ 2054*4882a593Smuzhiyun #define DOT11_ACTION_CAT_MASK 0x7F /* category mask */ 2055*4882a593Smuzhiyun #define DOT11_ACTION_CAT_SPECT_MNG 0 /* category spectrum management */ 2056*4882a593Smuzhiyun #define DOT11_ACTION_CAT_QOS 1 /* category QoS */ 2057*4882a593Smuzhiyun #define DOT11_ACTION_CAT_DLS 2 /* category DLS */ 2058*4882a593Smuzhiyun #define DOT11_ACTION_CAT_BLOCKACK 3 /* category block ack */ 2059*4882a593Smuzhiyun #define DOT11_ACTION_CAT_PUBLIC 4 /* category public */ 2060*4882a593Smuzhiyun #define DOT11_ACTION_CAT_RRM 5 /* category radio measurements */ 2061*4882a593Smuzhiyun #define DOT11_ACTION_CAT_FBT 6 /* category fast bss transition */ 2062*4882a593Smuzhiyun #define DOT11_ACTION_CAT_HT 7 /* category for HT */ 2063*4882a593Smuzhiyun #define DOT11_ACTION_CAT_SA_QUERY 8 /* security association query */ 2064*4882a593Smuzhiyun #define DOT11_ACTION_CAT_PDPA 9 /* protected dual of public action */ 2065*4882a593Smuzhiyun #define DOT11_ACTION_CAT_WNM 10 /* category for WNM */ 2066*4882a593Smuzhiyun #define DOT11_ACTION_CAT_UWNM 11 /* category for Unprotected WNM */ 2067*4882a593Smuzhiyun #define DOT11_ACTION_CAT_MESH 13 /* category for Mesh */ 2068*4882a593Smuzhiyun #define DOT11_ACTION_CAT_SELFPROT 15 /* category for Mesh, self protected */ 2069*4882a593Smuzhiyun #define DOT11_ACTION_NOTIFICATION 17 2070*4882a593Smuzhiyun 2071*4882a593Smuzhiyun #define DOT11_ACTION_RAV_STREAMING 19 /* category for Robust AV streaming: 2072*4882a593Smuzhiyun * SCS, MSCS, etc. 2073*4882a593Smuzhiyun */ 2074*4882a593Smuzhiyun 2075*4882a593Smuzhiyun #define DOT11_ACTION_CAT_VHT 21 /* VHT action */ 2076*4882a593Smuzhiyun #define DOT11_ACTION_CAT_S1G 22 /* S1G action */ 2077*4882a593Smuzhiyun /* FIXME: Use temp. ID until ANA assigns one */ 2078*4882a593Smuzhiyun #define DOT11_ACTION_CAT_HE 27 /* HE action frame */ 2079*4882a593Smuzhiyun #define DOT11_ACTION_CAT_FILS 26 /* FILS action frame */ 2080*4882a593Smuzhiyun #define DOT11_ACTION_CAT_VSP 126 /* protected vendor specific */ 2081*4882a593Smuzhiyun #define DOT11_ACTION_CAT_VS 127 /* category Vendor Specific */ 2082*4882a593Smuzhiyun 2083*4882a593Smuzhiyun /* Spectrum Management Action IDs (sec 7.4.1) */ 2084*4882a593Smuzhiyun #define DOT11_SM_ACTION_M_REQ 0 /* d11 action measurement request */ 2085*4882a593Smuzhiyun #define DOT11_SM_ACTION_M_REP 1 /* d11 action measurement response */ 2086*4882a593Smuzhiyun #define DOT11_SM_ACTION_TPC_REQ 2 /* d11 action TPC request */ 2087*4882a593Smuzhiyun #define DOT11_SM_ACTION_TPC_REP 3 /* d11 action TPC response */ 2088*4882a593Smuzhiyun #define DOT11_SM_ACTION_CHANNEL_SWITCH 4 /* d11 action channel switch */ 2089*4882a593Smuzhiyun #define DOT11_SM_ACTION_EXT_CSA 5 /* d11 extened CSA for 11n */ 2090*4882a593Smuzhiyun 2091*4882a593Smuzhiyun /* QoS action ids */ 2092*4882a593Smuzhiyun #define DOT11_QOS_ACTION_ADDTS_REQ 0 /* d11 action ADDTS request */ 2093*4882a593Smuzhiyun #define DOT11_QOS_ACTION_ADDTS_RESP 1 /* d11 action ADDTS response */ 2094*4882a593Smuzhiyun #define DOT11_QOS_ACTION_DELTS 2 /* d11 action DELTS */ 2095*4882a593Smuzhiyun #define DOT11_QOS_ACTION_SCHEDULE 3 /* d11 action schedule */ 2096*4882a593Smuzhiyun #define DOT11_QOS_ACTION_QOS_MAP 4 /* d11 action QOS map */ 2097*4882a593Smuzhiyun 2098*4882a593Smuzhiyun /* HT action ids */ 2099*4882a593Smuzhiyun #define DOT11_ACTION_ID_HT_CH_WIDTH 0 /* notify channel width action id */ 2100*4882a593Smuzhiyun #define DOT11_ACTION_ID_HT_MIMO_PS 1 /* mimo ps action id */ 2101*4882a593Smuzhiyun 2102*4882a593Smuzhiyun /* Public action ids */ 2103*4882a593Smuzhiyun #define DOT11_PUB_ACTION_BSS_COEX_MNG 0 /* 20/40 Coexistence Management action id */ 2104*4882a593Smuzhiyun #define DOT11_PUB_ACTION_CHANNEL_SWITCH 4 /* d11 action channel switch */ 2105*4882a593Smuzhiyun #define DOT11_PUB_ACTION_VENDOR_SPEC 9 /* Vendor specific */ 2106*4882a593Smuzhiyun #define DOT11_PUB_ACTION_GAS_CB_REQ 12 /* GAS Comeback Request */ 2107*4882a593Smuzhiyun #define DOT11_PUB_ACTION_FTM_REQ 32 /* FTM request */ 2108*4882a593Smuzhiyun #define DOT11_PUB_ACTION_FTM 33 /* FTM measurement */ 2109*4882a593Smuzhiyun /* unassigned value. Will change after final assignement. 2110*4882a593Smuzhiyun * for now, use 34(same as FILS DISC) due to QT/TB/chipsim support from uCode 2111*4882a593Smuzhiyun */ 2112*4882a593Smuzhiyun #define DOT11_PUB_ACTION_FTM_LMR 34 /* FTM 11AZ Location Management Report */ 2113*4882a593Smuzhiyun 2114*4882a593Smuzhiyun #define DOT11_PUB_ACTION_FTM_REQ_TRIGGER_START 1u /* FTM request start trigger */ 2115*4882a593Smuzhiyun #define DOT11_PUB_ACTION_FTM_REQ_TRIGGER_STOP 0u /* FTM request stop trigger */ 2116*4882a593Smuzhiyun 2117*4882a593Smuzhiyun /* Block Ack action types */ 2118*4882a593Smuzhiyun #define DOT11_BA_ACTION_ADDBA_REQ 0 /* ADDBA Req action frame type */ 2119*4882a593Smuzhiyun #define DOT11_BA_ACTION_ADDBA_RESP 1 /* ADDBA Resp action frame type */ 2120*4882a593Smuzhiyun #define DOT11_BA_ACTION_DELBA 2 /* DELBA action frame type */ 2121*4882a593Smuzhiyun 2122*4882a593Smuzhiyun /* ADDBA action parameters */ 2123*4882a593Smuzhiyun #define DOT11_ADDBA_PARAM_AMSDU_SUP 0x0001 /* AMSDU supported under BA */ 2124*4882a593Smuzhiyun #define DOT11_ADDBA_PARAM_POLICY_MASK 0x0002 /* policy mask(ack vs delayed) */ 2125*4882a593Smuzhiyun #define DOT11_ADDBA_PARAM_POLICY_SHIFT 1 /* policy shift */ 2126*4882a593Smuzhiyun #define DOT11_ADDBA_PARAM_TID_MASK 0x003c /* tid mask */ 2127*4882a593Smuzhiyun #define DOT11_ADDBA_PARAM_TID_SHIFT 2 /* tid shift */ 2128*4882a593Smuzhiyun #define DOT11_ADDBA_PARAM_BSIZE_MASK 0xffc0 /* buffer size mask */ 2129*4882a593Smuzhiyun #define DOT11_ADDBA_PARAM_BSIZE_SHIFT 6 /* buffer size shift */ 2130*4882a593Smuzhiyun 2131*4882a593Smuzhiyun #define DOT11_ADDBA_POLICY_DELAYED 0 /* delayed BA policy */ 2132*4882a593Smuzhiyun #define DOT11_ADDBA_POLICY_IMMEDIATE 1 /* immediate BA policy */ 2133*4882a593Smuzhiyun 2134*4882a593Smuzhiyun /* Fast Transition action types */ 2135*4882a593Smuzhiyun #define DOT11_FT_ACTION_FT_RESERVED 0 2136*4882a593Smuzhiyun #define DOT11_FT_ACTION_FT_REQ 1 /* FBT request - for over-the-DS FBT */ 2137*4882a593Smuzhiyun #define DOT11_FT_ACTION_FT_RES 2 /* FBT response - for over-the-DS FBT */ 2138*4882a593Smuzhiyun #define DOT11_FT_ACTION_FT_CON 3 /* FBT confirm - for OTDS with RRP */ 2139*4882a593Smuzhiyun #define DOT11_FT_ACTION_FT_ACK 4 /* FBT ack */ 2140*4882a593Smuzhiyun 2141*4882a593Smuzhiyun /* DLS action types */ 2142*4882a593Smuzhiyun #define DOT11_DLS_ACTION_REQ 0 /* DLS Request */ 2143*4882a593Smuzhiyun #define DOT11_DLS_ACTION_RESP 1 /* DLS Response */ 2144*4882a593Smuzhiyun #define DOT11_DLS_ACTION_TD 2 /* DLS Teardown */ 2145*4882a593Smuzhiyun 2146*4882a593Smuzhiyun /* Robust Audio Video streaming action types */ 2147*4882a593Smuzhiyun #define DOT11_RAV_SCS_REQ 0 /* SCS Request */ 2148*4882a593Smuzhiyun #define DOT11_RAV_SCS_RES 1 /* SCS Response */ 2149*4882a593Smuzhiyun #define DOT11_RAV_GM_REQ 2 /* Group Membership Request */ 2150*4882a593Smuzhiyun #define DOT11_RAV_GM_RES 3 /* Group Membership Response */ 2151*4882a593Smuzhiyun #define DOT11_RAV_MSCS_REQ 4 /* MSCS Request */ 2152*4882a593Smuzhiyun #define DOT11_RAV_MSCS_RES 5 /* MSCS Response */ 2153*4882a593Smuzhiyun 2154*4882a593Smuzhiyun /* Wireless Network Management (WNM) action types */ 2155*4882a593Smuzhiyun #define DOT11_WNM_ACTION_EVENT_REQ 0 2156*4882a593Smuzhiyun #define DOT11_WNM_ACTION_EVENT_REP 1 2157*4882a593Smuzhiyun #define DOT11_WNM_ACTION_DIAG_REQ 2 2158*4882a593Smuzhiyun #define DOT11_WNM_ACTION_DIAG_REP 3 2159*4882a593Smuzhiyun #define DOT11_WNM_ACTION_LOC_CFG_REQ 4 2160*4882a593Smuzhiyun #define DOT11_WNM_ACTION_LOC_RFG_RESP 5 2161*4882a593Smuzhiyun #define DOT11_WNM_ACTION_BSSTRANS_QUERY 6 2162*4882a593Smuzhiyun #define DOT11_WNM_ACTION_BSSTRANS_REQ 7 2163*4882a593Smuzhiyun #define DOT11_WNM_ACTION_BSSTRANS_RESP 8 2164*4882a593Smuzhiyun #define DOT11_WNM_ACTION_FMS_REQ 9 2165*4882a593Smuzhiyun #define DOT11_WNM_ACTION_FMS_RESP 10 2166*4882a593Smuzhiyun #define DOT11_WNM_ACTION_COL_INTRFRNCE_REQ 11 2167*4882a593Smuzhiyun #define DOT11_WNM_ACTION_COL_INTRFRNCE_REP 12 2168*4882a593Smuzhiyun #define DOT11_WNM_ACTION_TFS_REQ 13 2169*4882a593Smuzhiyun #define DOT11_WNM_ACTION_TFS_RESP 14 2170*4882a593Smuzhiyun #define DOT11_WNM_ACTION_TFS_NOTIFY_REQ 15 2171*4882a593Smuzhiyun #define DOT11_WNM_ACTION_WNM_SLEEP_REQ 16 2172*4882a593Smuzhiyun #define DOT11_WNM_ACTION_WNM_SLEEP_RESP 17 2173*4882a593Smuzhiyun #define DOT11_WNM_ACTION_TIMBC_REQ 18 2174*4882a593Smuzhiyun #define DOT11_WNM_ACTION_TIMBC_RESP 19 2175*4882a593Smuzhiyun #define DOT11_WNM_ACTION_QOS_TRFC_CAP_UPD 20 2176*4882a593Smuzhiyun #define DOT11_WNM_ACTION_CHAN_USAGE_REQ 21 2177*4882a593Smuzhiyun #define DOT11_WNM_ACTION_CHAN_USAGE_RESP 22 2178*4882a593Smuzhiyun #define DOT11_WNM_ACTION_DMS_REQ 23 2179*4882a593Smuzhiyun #define DOT11_WNM_ACTION_DMS_RESP 24 2180*4882a593Smuzhiyun #define DOT11_WNM_ACTION_TMNG_MEASUR_REQ 25 2181*4882a593Smuzhiyun #define DOT11_WNM_ACTION_NOTFCTN_REQ 26 2182*4882a593Smuzhiyun #define DOT11_WNM_ACTION_NOTFCTN_RESP 27 2183*4882a593Smuzhiyun #define DOT11_WNM_ACTION_TFS_NOTIFY_RESP 28 2184*4882a593Smuzhiyun 2185*4882a593Smuzhiyun /* Unprotected Wireless Network Management (WNM) action types */ 2186*4882a593Smuzhiyun #define DOT11_UWNM_ACTION_TIM 0 2187*4882a593Smuzhiyun #define DOT11_UWNM_ACTION_TIMING_MEASUREMENT 1 2188*4882a593Smuzhiyun 2189*4882a593Smuzhiyun #define DOT11_MNG_COUNTRY_ID_LEN 3 2190*4882a593Smuzhiyun 2191*4882a593Smuzhiyun /* VHT category action types - 802.11ac D3.0 - 8.5.23.1 */ 2192*4882a593Smuzhiyun #define DOT11_VHT_ACTION_CBF 0 /* Compressed Beamforming */ 2193*4882a593Smuzhiyun #define DOT11_VHT_ACTION_GID_MGMT 1 /* Group ID Management */ 2194*4882a593Smuzhiyun #define DOT11_VHT_ACTION_OPER_MODE_NOTIF 2 /* Operating mode notif'n */ 2195*4882a593Smuzhiyun 2196*4882a593Smuzhiyun /* FILS category action types - 802.11ai D11.0 - 9.6.8.1 */ 2197*4882a593Smuzhiyun #define DOT11_FILS_ACTION_DISCOVERY 34 /* FILS Discovery */ 2198*4882a593Smuzhiyun 2199*4882a593Smuzhiyun /** DLS Request frame header */ 2200*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_dls_req { 2201*4882a593Smuzhiyun uint8 category; /* category of action frame (2) */ 2202*4882a593Smuzhiyun uint8 action; /* DLS action: req (0) */ 2203*4882a593Smuzhiyun struct ether_addr da; /* destination address */ 2204*4882a593Smuzhiyun struct ether_addr sa; /* source address */ 2205*4882a593Smuzhiyun uint16 cap; /* capability */ 2206*4882a593Smuzhiyun uint16 timeout; /* timeout value */ 2207*4882a593Smuzhiyun uint8 data[1]; /* IE:support rate, extend support rate, HT cap */ 2208*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2209*4882a593Smuzhiyun typedef struct dot11_dls_req dot11_dls_req_t; 2210*4882a593Smuzhiyun #define DOT11_DLS_REQ_LEN 18 /* Fixed length */ 2211*4882a593Smuzhiyun 2212*4882a593Smuzhiyun /** DLS response frame header */ 2213*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_dls_resp { 2214*4882a593Smuzhiyun uint8 category; /* category of action frame (2) */ 2215*4882a593Smuzhiyun uint8 action; /* DLS action: req (0) */ 2216*4882a593Smuzhiyun uint16 status; /* status code field */ 2217*4882a593Smuzhiyun struct ether_addr da; /* destination address */ 2218*4882a593Smuzhiyun struct ether_addr sa; /* source address */ 2219*4882a593Smuzhiyun uint8 data[1]; /* optional: capability, rate ... */ 2220*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2221*4882a593Smuzhiyun typedef struct dot11_dls_resp dot11_dls_resp_t; 2222*4882a593Smuzhiyun #define DOT11_DLS_RESP_LEN 16 /* Fixed length */ 2223*4882a593Smuzhiyun 2224*4882a593Smuzhiyun /* ************* 802.11v related definitions. ************* */ 2225*4882a593Smuzhiyun 2226*4882a593Smuzhiyun /** BSS Management Transition Query frame header */ 2227*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_bsstrans_query { 2228*4882a593Smuzhiyun uint8 category; /* category of action frame (10) */ 2229*4882a593Smuzhiyun uint8 action; /* WNM action: trans_query (6) */ 2230*4882a593Smuzhiyun uint8 token; /* dialog token */ 2231*4882a593Smuzhiyun uint8 reason; /* transition query reason */ 2232*4882a593Smuzhiyun uint8 data[1]; /* Elements */ 2233*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2234*4882a593Smuzhiyun typedef struct dot11_bsstrans_query dot11_bsstrans_query_t; 2235*4882a593Smuzhiyun #define DOT11_BSSTRANS_QUERY_LEN 4 /* Fixed length */ 2236*4882a593Smuzhiyun 2237*4882a593Smuzhiyun /* BTM transition reason */ 2238*4882a593Smuzhiyun #define DOT11_BSSTRANS_REASON_UNSPECIFIED 0 2239*4882a593Smuzhiyun #define DOT11_BSSTRANS_REASON_EXC_FRAME_LOSS 1 2240*4882a593Smuzhiyun #define DOT11_BSSTRANS_REASON_EXC_TRAFFIC_DELAY 2 2241*4882a593Smuzhiyun #define DOT11_BSSTRANS_REASON_INSUFF_QOS_CAPACITY 3 2242*4882a593Smuzhiyun #define DOT11_BSSTRANS_REASON_FIRST_ASSOC 4 2243*4882a593Smuzhiyun #define DOT11_BSSTRANS_REASON_LOAD_BALANCING 5 2244*4882a593Smuzhiyun #define DOT11_BSSTRANS_REASON_BETTER_AP_FOUND 6 2245*4882a593Smuzhiyun #define DOT11_BSSTRANS_REASON_DEAUTH_RX 7 2246*4882a593Smuzhiyun #define DOT11_BSSTRANS_REASON_8021X_EAP_AUTH_FAIL 8 2247*4882a593Smuzhiyun #define DOT11_BSSTRANS_REASON_4WAY_HANDSHK_FAIL 9 2248*4882a593Smuzhiyun #define DOT11_BSSTRANS_REASON_MANY_REPLAYCNT_FAIL 10 2249*4882a593Smuzhiyun #define DOT11_BSSTRANS_REASON_MANY_DATAMIC_FAIL 11 2250*4882a593Smuzhiyun #define DOT11_BSSTRANS_REASON_EXCEED_MAX_RETRANS 12 2251*4882a593Smuzhiyun #define DOT11_BSSTRANS_REASON_MANY_BCAST_DISASSOC_RX 13 2252*4882a593Smuzhiyun #define DOT11_BSSTRANS_REASON_MANY_BCAST_DEAUTH_RX 14 2253*4882a593Smuzhiyun #define DOT11_BSSTRANS_REASON_PREV_TRANSITION_FAIL 15 2254*4882a593Smuzhiyun #define DOT11_BSSTRANS_REASON_LOW_RSSI 16 2255*4882a593Smuzhiyun #define DOT11_BSSTRANS_REASON_ROAM_FROM_NON_80211 17 2256*4882a593Smuzhiyun #define DOT11_BSSTRANS_REASON_RX_BTM_REQ 18 2257*4882a593Smuzhiyun #define DOT11_BSSTRANS_REASON_PREF_LIST_INCLUDED 19 2258*4882a593Smuzhiyun #define DOT11_BSSTRANS_REASON_LEAVING_ESS 20 2259*4882a593Smuzhiyun 2260*4882a593Smuzhiyun /** BSS Management Transition Request frame header */ 2261*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_bsstrans_req { 2262*4882a593Smuzhiyun uint8 category; /* category of action frame (10) */ 2263*4882a593Smuzhiyun uint8 action; /* WNM action: trans_req (7) */ 2264*4882a593Smuzhiyun uint8 token; /* dialog token */ 2265*4882a593Smuzhiyun uint8 reqmode; /* transition request mode */ 2266*4882a593Smuzhiyun uint16 disassoc_tmr; /* disassociation timer */ 2267*4882a593Smuzhiyun uint8 validity_intrvl; /* validity interval */ 2268*4882a593Smuzhiyun uint8 data[1]; /* optional: BSS term duration, ... */ 2269*4882a593Smuzhiyun /* ...session info URL, candidate list */ 2270*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2271*4882a593Smuzhiyun typedef struct dot11_bsstrans_req dot11_bsstrans_req_t; 2272*4882a593Smuzhiyun #define DOT11_BSSTRANS_REQ_LEN 7 /* Fixed length */ 2273*4882a593Smuzhiyun #define DOT11_BSSTRANS_REQ_FIXED_LEN 7u /* Fixed length */ 2274*4882a593Smuzhiyun 2275*4882a593Smuzhiyun /* BSS Mgmt Transition Request Mode Field - 802.11v */ 2276*4882a593Smuzhiyun #define DOT11_BSSTRANS_REQMODE_PREF_LIST_INCL 0x01 2277*4882a593Smuzhiyun #define DOT11_BSSTRANS_REQMODE_ABRIDGED 0x02 2278*4882a593Smuzhiyun #define DOT11_BSSTRANS_REQMODE_DISASSOC_IMMINENT 0x04 2279*4882a593Smuzhiyun #define DOT11_BSSTRANS_REQMODE_BSS_TERM_INCL 0x08 2280*4882a593Smuzhiyun #define DOT11_BSSTRANS_REQMODE_ESS_DISASSOC_IMNT 0x10 2281*4882a593Smuzhiyun 2282*4882a593Smuzhiyun /** BSS Management transition response frame header */ 2283*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_bsstrans_resp { 2284*4882a593Smuzhiyun uint8 category; /* category of action frame (10) */ 2285*4882a593Smuzhiyun uint8 action; /* WNM action: trans_resp (8) */ 2286*4882a593Smuzhiyun uint8 token; /* dialog token */ 2287*4882a593Smuzhiyun uint8 status; /* transition status */ 2288*4882a593Smuzhiyun uint8 term_delay; /* validity interval */ 2289*4882a593Smuzhiyun uint8 data[1]; /* optional: BSSID target, candidate list */ 2290*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2291*4882a593Smuzhiyun typedef struct dot11_bsstrans_resp dot11_bsstrans_resp_t; 2292*4882a593Smuzhiyun #define DOT11_BSSTRANS_RESP_LEN 5 /* Fixed length */ 2293*4882a593Smuzhiyun 2294*4882a593Smuzhiyun /* BSS Mgmt Transition Response Status Field */ 2295*4882a593Smuzhiyun #define DOT11_BSSTRANS_RESP_STATUS_ACCEPT 0 2296*4882a593Smuzhiyun #define DOT11_BSSTRANS_RESP_STATUS_REJECT 1 2297*4882a593Smuzhiyun #define DOT11_BSSTRANS_RESP_STATUS_REJ_INSUFF_BCN 2 2298*4882a593Smuzhiyun #define DOT11_BSSTRANS_RESP_STATUS_REJ_INSUFF_CAP 3 2299*4882a593Smuzhiyun #define DOT11_BSSTRANS_RESP_STATUS_REJ_TERM_UNDESIRED 4 2300*4882a593Smuzhiyun #define DOT11_BSSTRANS_RESP_STATUS_REJ_TERM_DELAY_REQ 5 2301*4882a593Smuzhiyun #define DOT11_BSSTRANS_RESP_STATUS_REJ_BSS_LIST_PROVIDED 6 2302*4882a593Smuzhiyun #define DOT11_BSSTRANS_RESP_STATUS_REJ_NO_SUITABLE_BSS 7 2303*4882a593Smuzhiyun #define DOT11_BSSTRANS_RESP_STATUS_REJ_LEAVING_ESS 8 2304*4882a593Smuzhiyun 2305*4882a593Smuzhiyun /** BSS Max Idle Period element */ 2306*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_bss_max_idle_period_ie { 2307*4882a593Smuzhiyun uint8 id; /* 90, DOT11_MNG_BSS_MAX_IDLE_PERIOD_ID */ 2308*4882a593Smuzhiyun uint8 len; 2309*4882a593Smuzhiyun uint16 max_idle_period; /* in unit of 1000 TUs */ 2310*4882a593Smuzhiyun uint8 idle_opt; 2311*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2312*4882a593Smuzhiyun typedef struct dot11_bss_max_idle_period_ie dot11_bss_max_idle_period_ie_t; 2313*4882a593Smuzhiyun #define DOT11_BSS_MAX_IDLE_PERIOD_IE_LEN 3 /* bss max idle period IE size */ 2314*4882a593Smuzhiyun #define DOT11_BSS_MAX_IDLE_PERIOD_OPT_PROTECTED 1 /* BSS max idle option */ 2315*4882a593Smuzhiyun 2316*4882a593Smuzhiyun /** TIM Broadcast request element */ 2317*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_timbc_req_ie { 2318*4882a593Smuzhiyun uint8 id; /* 94, DOT11_MNG_TIMBC_REQ_ID */ 2319*4882a593Smuzhiyun uint8 len; 2320*4882a593Smuzhiyun uint8 interval; /* in unit of beacon interval */ 2321*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2322*4882a593Smuzhiyun typedef struct dot11_timbc_req_ie dot11_timbc_req_ie_t; 2323*4882a593Smuzhiyun #define DOT11_TIMBC_REQ_IE_LEN 1 /* Fixed length */ 2324*4882a593Smuzhiyun 2325*4882a593Smuzhiyun /** TIM Broadcast request frame header */ 2326*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_timbc_req { 2327*4882a593Smuzhiyun uint8 category; /* category of action frame (10) */ 2328*4882a593Smuzhiyun uint8 action; /* WNM action: DOT11_WNM_ACTION_TIMBC_REQ(18) */ 2329*4882a593Smuzhiyun uint8 token; /* dialog token */ 2330*4882a593Smuzhiyun uint8 data[1]; /* TIM broadcast request element */ 2331*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2332*4882a593Smuzhiyun typedef struct dot11_timbc_req dot11_timbc_req_t; 2333*4882a593Smuzhiyun #define DOT11_TIMBC_REQ_LEN 3 /* Fixed length */ 2334*4882a593Smuzhiyun 2335*4882a593Smuzhiyun /** TIM Broadcast response element */ 2336*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_timbc_resp_ie { 2337*4882a593Smuzhiyun uint8 id; /* 95, DOT11_MNG_TIM_BROADCAST_RESP_ID */ 2338*4882a593Smuzhiyun uint8 len; 2339*4882a593Smuzhiyun uint8 status; /* status of add request */ 2340*4882a593Smuzhiyun uint8 interval; /* in unit of beacon interval */ 2341*4882a593Smuzhiyun int32 offset; /* in unit of ms */ 2342*4882a593Smuzhiyun uint16 high_rate; /* in unit of 0.5 Mb/s */ 2343*4882a593Smuzhiyun uint16 low_rate; /* in unit of 0.5 Mb/s */ 2344*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2345*4882a593Smuzhiyun typedef struct dot11_timbc_resp_ie dot11_timbc_resp_ie_t; 2346*4882a593Smuzhiyun #define DOT11_TIMBC_DENY_RESP_IE_LEN 1 /* Deny. Fixed length */ 2347*4882a593Smuzhiyun #define DOT11_TIMBC_ACCEPT_RESP_IE_LEN 10 /* Accept. Fixed length */ 2348*4882a593Smuzhiyun 2349*4882a593Smuzhiyun #define DOT11_TIMBC_STATUS_ACCEPT 0 2350*4882a593Smuzhiyun #define DOT11_TIMBC_STATUS_ACCEPT_TSTAMP 1 2351*4882a593Smuzhiyun #define DOT11_TIMBC_STATUS_DENY 2 2352*4882a593Smuzhiyun #define DOT11_TIMBC_STATUS_OVERRIDDEN 3 2353*4882a593Smuzhiyun #define DOT11_TIMBC_STATUS_RESERVED 4 2354*4882a593Smuzhiyun 2355*4882a593Smuzhiyun /** TIM Broadcast request frame header */ 2356*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_timbc_resp { 2357*4882a593Smuzhiyun uint8 category; /* category of action frame (10) */ 2358*4882a593Smuzhiyun uint8 action; /* action: DOT11_WNM_ACTION_TIMBC_RESP(19) */ 2359*4882a593Smuzhiyun uint8 token; /* dialog token */ 2360*4882a593Smuzhiyun uint8 data[1]; /* TIM broadcast response element */ 2361*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2362*4882a593Smuzhiyun typedef struct dot11_timbc_resp dot11_timbc_resp_t; 2363*4882a593Smuzhiyun #define DOT11_TIMBC_RESP_LEN 3 /* Fixed length */ 2364*4882a593Smuzhiyun 2365*4882a593Smuzhiyun /** TIM element */ 2366*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_tim_ie { 2367*4882a593Smuzhiyun uint8 id; /* 5, DOT11_MNG_TIM_ID */ 2368*4882a593Smuzhiyun uint8 len; /* 4 - 255 */ 2369*4882a593Smuzhiyun uint8 dtim_count; /* DTIM decrementing counter */ 2370*4882a593Smuzhiyun uint8 dtim_period; /* DTIM period */ 2371*4882a593Smuzhiyun uint8 bitmap_control; /* AID 0 + bitmap offset */ 2372*4882a593Smuzhiyun uint8 pvb[1]; /* Partial Virtual Bitmap, variable length */ 2373*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2374*4882a593Smuzhiyun typedef struct dot11_tim_ie dot11_tim_ie_t; 2375*4882a593Smuzhiyun #define DOT11_TIM_IE_FIXED_LEN 3 /* Fixed length, without id and len */ 2376*4882a593Smuzhiyun #define DOT11_TIM_IE_FIXED_TOTAL_LEN 5 /* Fixed length, with id and len */ 2377*4882a593Smuzhiyun 2378*4882a593Smuzhiyun /** TIM Broadcast frame header */ 2379*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_timbc { 2380*4882a593Smuzhiyun uint8 category; /* category of action frame (11) */ 2381*4882a593Smuzhiyun uint8 action; /* action: TIM (0) */ 2382*4882a593Smuzhiyun uint8 check_beacon; /* need to check-beacon */ 2383*4882a593Smuzhiyun uint8 tsf[8]; /* Time Synchronization Function */ 2384*4882a593Smuzhiyun dot11_tim_ie_t tim_ie; /* TIM element */ 2385*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2386*4882a593Smuzhiyun typedef struct dot11_timbc dot11_timbc_t; 2387*4882a593Smuzhiyun #define DOT11_TIMBC_HDR_LEN (sizeof(dot11_timbc_t) - sizeof(dot11_tim_ie_t)) 2388*4882a593Smuzhiyun #define DOT11_TIMBC_FIXED_LEN (sizeof(dot11_timbc_t) - 1) /* Fixed length */ 2389*4882a593Smuzhiyun #define DOT11_TIMBC_LEN 11 /* Fixed length */ 2390*4882a593Smuzhiyun 2391*4882a593Smuzhiyun /** TCLAS frame classifier type */ 2392*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_tclas_fc_hdr { 2393*4882a593Smuzhiyun uint8 type; 2394*4882a593Smuzhiyun uint8 mask; 2395*4882a593Smuzhiyun uint8 data[1]; 2396*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2397*4882a593Smuzhiyun typedef struct dot11_tclas_fc_hdr dot11_tclas_fc_hdr_t; 2398*4882a593Smuzhiyun #define DOT11_TCLAS_FC_HDR_LEN 2 /* Fixed length */ 2399*4882a593Smuzhiyun 2400*4882a593Smuzhiyun #define DOT11_TCLAS_MASK_0 0x1 2401*4882a593Smuzhiyun #define DOT11_TCLAS_MASK_1 0x2 2402*4882a593Smuzhiyun #define DOT11_TCLAS_MASK_2 0x4 2403*4882a593Smuzhiyun #define DOT11_TCLAS_MASK_3 0x8 2404*4882a593Smuzhiyun #define DOT11_TCLAS_MASK_4 0x10 2405*4882a593Smuzhiyun #define DOT11_TCLAS_MASK_5 0x20 2406*4882a593Smuzhiyun #define DOT11_TCLAS_MASK_6 0x40 2407*4882a593Smuzhiyun #define DOT11_TCLAS_MASK_7 0x80 2408*4882a593Smuzhiyun 2409*4882a593Smuzhiyun #define DOT11_TCLAS_FC_0_ETH 0 2410*4882a593Smuzhiyun #define DOT11_TCLAS_FC_1_IP 1 2411*4882a593Smuzhiyun #define DOT11_TCLAS_FC_2_8021Q 2 2412*4882a593Smuzhiyun #define DOT11_TCLAS_FC_3_OFFSET 3 2413*4882a593Smuzhiyun #define DOT11_TCLAS_FC_4_IP_HIGHER 4 2414*4882a593Smuzhiyun #define DOT11_TCLAS_FC_5_8021D 5 2415*4882a593Smuzhiyun 2416*4882a593Smuzhiyun /** TCLAS frame classifier type 0 parameters for Ethernet */ 2417*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_tclas_fc_0_eth { 2418*4882a593Smuzhiyun uint8 type; 2419*4882a593Smuzhiyun uint8 mask; 2420*4882a593Smuzhiyun uint8 sa[ETHER_ADDR_LEN]; 2421*4882a593Smuzhiyun uint8 da[ETHER_ADDR_LEN]; 2422*4882a593Smuzhiyun uint16 eth_type; 2423*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2424*4882a593Smuzhiyun typedef struct dot11_tclas_fc_0_eth dot11_tclas_fc_0_eth_t; 2425*4882a593Smuzhiyun #define DOT11_TCLAS_FC_0_ETH_LEN 16 2426*4882a593Smuzhiyun 2427*4882a593Smuzhiyun /** TCLAS frame classifier type 1 parameters for IPV4 */ 2428*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_tclas_fc_1_ipv4 { 2429*4882a593Smuzhiyun uint8 type; 2430*4882a593Smuzhiyun uint8 mask; 2431*4882a593Smuzhiyun uint8 version; 2432*4882a593Smuzhiyun uint32 src_ip; 2433*4882a593Smuzhiyun uint32 dst_ip; 2434*4882a593Smuzhiyun uint16 src_port; 2435*4882a593Smuzhiyun uint16 dst_port; 2436*4882a593Smuzhiyun uint8 dscp; 2437*4882a593Smuzhiyun uint8 protocol; 2438*4882a593Smuzhiyun uint8 reserved; 2439*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2440*4882a593Smuzhiyun typedef struct dot11_tclas_fc_1_ipv4 dot11_tclas_fc_1_ipv4_t; 2441*4882a593Smuzhiyun #define DOT11_TCLAS_FC_1_IPV4_LEN 18 2442*4882a593Smuzhiyun 2443*4882a593Smuzhiyun /** TCLAS frame classifier type 2 parameters for 802.1Q */ 2444*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_tclas_fc_2_8021q { 2445*4882a593Smuzhiyun uint8 type; 2446*4882a593Smuzhiyun uint8 mask; 2447*4882a593Smuzhiyun uint16 tci; 2448*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2449*4882a593Smuzhiyun typedef struct dot11_tclas_fc_2_8021q dot11_tclas_fc_2_8021q_t; 2450*4882a593Smuzhiyun #define DOT11_TCLAS_FC_2_8021Q_LEN 4 2451*4882a593Smuzhiyun 2452*4882a593Smuzhiyun /** TCLAS frame classifier type 3 parameters for filter offset */ 2453*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_tclas_fc_3_filter { 2454*4882a593Smuzhiyun uint8 type; 2455*4882a593Smuzhiyun uint8 mask; 2456*4882a593Smuzhiyun uint16 offset; 2457*4882a593Smuzhiyun uint8 data[1]; 2458*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2459*4882a593Smuzhiyun typedef struct dot11_tclas_fc_3_filter dot11_tclas_fc_3_filter_t; 2460*4882a593Smuzhiyun #define DOT11_TCLAS_FC_3_FILTER_LEN 4 2461*4882a593Smuzhiyun 2462*4882a593Smuzhiyun /** TCLAS frame classifier type 4 parameters for IPV4 is the same as TCLAS type 1 */ 2463*4882a593Smuzhiyun typedef struct dot11_tclas_fc_1_ipv4 dot11_tclas_fc_4_ipv4_t; 2464*4882a593Smuzhiyun #define DOT11_TCLAS_FC_4_IPV4_LEN DOT11_TCLAS_FC_1_IPV4_LEN 2465*4882a593Smuzhiyun 2466*4882a593Smuzhiyun /** TCLAS frame classifier type 4 parameters for IPV6 */ 2467*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_tclas_fc_4_ipv6 { 2468*4882a593Smuzhiyun uint8 type; 2469*4882a593Smuzhiyun uint8 mask; 2470*4882a593Smuzhiyun uint8 version; 2471*4882a593Smuzhiyun uint8 saddr[16]; 2472*4882a593Smuzhiyun uint8 daddr[16]; 2473*4882a593Smuzhiyun uint16 src_port; 2474*4882a593Smuzhiyun uint16 dst_port; 2475*4882a593Smuzhiyun uint8 dscp; 2476*4882a593Smuzhiyun uint8 nexthdr; 2477*4882a593Smuzhiyun uint8 flow_lbl[3]; 2478*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2479*4882a593Smuzhiyun typedef struct dot11_tclas_fc_4_ipv6 dot11_tclas_fc_4_ipv6_t; 2480*4882a593Smuzhiyun #define DOT11_TCLAS_FC_4_IPV6_LEN 44 2481*4882a593Smuzhiyun 2482*4882a593Smuzhiyun /** TCLAS frame classifier type 5 parameters for 802.1D */ 2483*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_tclas_fc_5_8021d { 2484*4882a593Smuzhiyun uint8 type; 2485*4882a593Smuzhiyun uint8 mask; 2486*4882a593Smuzhiyun uint8 pcp; 2487*4882a593Smuzhiyun uint8 cfi; 2488*4882a593Smuzhiyun uint16 vid; 2489*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2490*4882a593Smuzhiyun typedef struct dot11_tclas_fc_5_8021d dot11_tclas_fc_5_8021d_t; 2491*4882a593Smuzhiyun #define DOT11_TCLAS_FC_5_8021D_LEN 6 2492*4882a593Smuzhiyun 2493*4882a593Smuzhiyun /** TCLAS frame classifier type parameters */ 2494*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT union dot11_tclas_fc { 2495*4882a593Smuzhiyun uint8 data[1]; 2496*4882a593Smuzhiyun dot11_tclas_fc_hdr_t hdr; 2497*4882a593Smuzhiyun dot11_tclas_fc_0_eth_t t0_eth; 2498*4882a593Smuzhiyun dot11_tclas_fc_1_ipv4_t t1_ipv4; 2499*4882a593Smuzhiyun dot11_tclas_fc_2_8021q_t t2_8021q; 2500*4882a593Smuzhiyun dot11_tclas_fc_3_filter_t t3_filter; 2501*4882a593Smuzhiyun dot11_tclas_fc_4_ipv4_t t4_ipv4; 2502*4882a593Smuzhiyun dot11_tclas_fc_4_ipv6_t t4_ipv6; 2503*4882a593Smuzhiyun dot11_tclas_fc_5_8021d_t t5_8021d; 2504*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2505*4882a593Smuzhiyun typedef union dot11_tclas_fc dot11_tclas_fc_t; 2506*4882a593Smuzhiyun 2507*4882a593Smuzhiyun #define DOT11_TCLAS_FC_MIN_LEN 4 /* Classifier Type 2 has the min size */ 2508*4882a593Smuzhiyun #define DOT11_TCLAS_FC_MAX_LEN 254 2509*4882a593Smuzhiyun 2510*4882a593Smuzhiyun /** TCLAS element */ 2511*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_tclas_ie { 2512*4882a593Smuzhiyun uint8 id; /* 14, DOT11_MNG_TCLAS_ID */ 2513*4882a593Smuzhiyun uint8 len; 2514*4882a593Smuzhiyun uint8 user_priority; 2515*4882a593Smuzhiyun dot11_tclas_fc_t fc; 2516*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2517*4882a593Smuzhiyun typedef struct dot11_tclas_ie dot11_tclas_ie_t; 2518*4882a593Smuzhiyun #define DOT11_TCLAS_IE_LEN 3u /* Fixed length, include id and len */ 2519*4882a593Smuzhiyun 2520*4882a593Smuzhiyun /** TCLAS processing element */ 2521*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_tclas_proc_ie { 2522*4882a593Smuzhiyun uint8 id; /* 44, DOT11_MNG_TCLAS_PROC_ID */ 2523*4882a593Smuzhiyun uint8 len; 2524*4882a593Smuzhiyun uint8 process; 2525*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2526*4882a593Smuzhiyun typedef struct dot11_tclas_proc_ie dot11_tclas_proc_ie_t; 2527*4882a593Smuzhiyun #define DOT11_TCLAS_PROC_IE_LEN 3 /* Fixed length, include id and len */ 2528*4882a593Smuzhiyun 2529*4882a593Smuzhiyun #define DOT11_TCLAS_PROC_LEN 1u /* Proc ie length is always 1 byte */ 2530*4882a593Smuzhiyun 2531*4882a593Smuzhiyun #define DOT11_TCLAS_PROC_MATCHALL 0 /* All high level element need to match */ 2532*4882a593Smuzhiyun #define DOT11_TCLAS_PROC_MATCHONE 1 /* One high level element need to match */ 2533*4882a593Smuzhiyun #define DOT11_TCLAS_PROC_NONMATCH 2 /* Non match to any high level element */ 2534*4882a593Smuzhiyun 2535*4882a593Smuzhiyun /* TSPEC element defined in 802.11 std section 8.4.2.32 - Not supported */ 2536*4882a593Smuzhiyun #define DOT11_TSPEC_IE_LEN 57 /* Fixed length */ 2537*4882a593Smuzhiyun 2538*4882a593Smuzhiyun /** TCLAS Mask element */ 2539*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_tclas_mask_ie { 2540*4882a593Smuzhiyun uint8 id; /* DOT11_MNG_ID_EXT_ID (255) */ 2541*4882a593Smuzhiyun uint8 len; 2542*4882a593Smuzhiyun uint8 id_ext; /* TCLAS_EXTID_MNG_MASK_ID (89) */ 2543*4882a593Smuzhiyun dot11_tclas_fc_t fc; /* Variable length frame classifier (fc) */ 2544*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2545*4882a593Smuzhiyun typedef struct dot11_tclas_mask_ie dot11_tclas_mask_ie_t; 2546*4882a593Smuzhiyun #define DOT11_TCLAS_MASK_IE_LEN 1u /* Fixed length, excludes id and len */ 2547*4882a593Smuzhiyun #define DOT11_TCLAS_MASK_IE_HDR_LEN 3u /* Fixed length */ 2548*4882a593Smuzhiyun 2549*4882a593Smuzhiyun /* Bitmap definitions for the User Priority Bitmap 2550*4882a593Smuzhiyun * Each bit in the bitmap corresponds to a user priority. 2551*4882a593Smuzhiyun */ 2552*4882a593Smuzhiyun #define DOT11_UP_CTRL_UP_0 0u 2553*4882a593Smuzhiyun #define DOT11_UP_CTRL_UP_1 1u 2554*4882a593Smuzhiyun #define DOT11_UP_CTRL_UP_2 2u 2555*4882a593Smuzhiyun #define DOT11_UP_CTRL_UP_3 3u 2556*4882a593Smuzhiyun #define DOT11_UP_CTRL_UP_4 4u 2557*4882a593Smuzhiyun #define DOT11_UP_CTRL_UP_5 5u 2558*4882a593Smuzhiyun #define DOT11_UP_CTRL_UP_6 6u 2559*4882a593Smuzhiyun #define DOT11_UP_CTRL_UP_7 7u 2560*4882a593Smuzhiyun 2561*4882a593Smuzhiyun /* User priority control (up_ctl) macros */ 2562*4882a593Smuzhiyun #define DOT11_UPC_UP_BITMAP_MASK 0xFFu /* UP bitmap mask */ 2563*4882a593Smuzhiyun #define DOT11_UPC_UP_BITMAP_SHIFT 0u /* UP bitmap shift */ 2564*4882a593Smuzhiyun #define DOT11_UPC_UP_LIMIT_MASK 0x700u /* UP limit mask */ 2565*4882a593Smuzhiyun #define DOT11_UPC_UP_LIMIT_SHIFT 8u /* UP limit shift */ 2566*4882a593Smuzhiyun 2567*4882a593Smuzhiyun /* MSCS Request Types */ 2568*4882a593Smuzhiyun #define DOT11_MSCS_REQ_TYPE_ADD 0u 2569*4882a593Smuzhiyun #define DOT11_MSCS_REQ_TYPE_REMOVE 1u 2570*4882a593Smuzhiyun #define DOT11_MSCS_REQ_TYPE_CHANGE 2u 2571*4882a593Smuzhiyun 2572*4882a593Smuzhiyun /** MSCS Descriptor element */ 2573*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_mscs_descr_ie { 2574*4882a593Smuzhiyun uint8 id; /* DOT11_MNG_ID_EXT_ID (255) */ 2575*4882a593Smuzhiyun uint8 len; 2576*4882a593Smuzhiyun uint8 id_ext; /* MSCS_EXTID_MNG_DESCR_ID (88) */ 2577*4882a593Smuzhiyun uint8 req_type; /* MSCS request type */ 2578*4882a593Smuzhiyun uint16 up_ctl; /* User priority control: 2579*4882a593Smuzhiyun * Bits 0..7, up_bitmap(8 bits); 2580*4882a593Smuzhiyun * Bits 8..10, up_limit (3 bits) 2581*4882a593Smuzhiyun * Bits 11..15 reserved (5 bits) 2582*4882a593Smuzhiyun */ 2583*4882a593Smuzhiyun uint32 stream_timeout; 2584*4882a593Smuzhiyun uint8 data[]; 2585*4882a593Smuzhiyun /* optional tclas mask elements */ /* dot11_tclas_mask_ie_t */ 2586*4882a593Smuzhiyun /* optional sub-elements */ 2587*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2588*4882a593Smuzhiyun typedef struct dot11_mscs_descr_ie dot11_mscs_descr_ie_t; 2589*4882a593Smuzhiyun #define DOT11_MSCS_DESCR_IE_LEN 8u /* Fixed length, exludes id and len */ 2590*4882a593Smuzhiyun #define DOT11_MSCS_DESCR_IE_HDR_LEN 10u /* Entire descriptor header length */ 2591*4882a593Smuzhiyun 2592*4882a593Smuzhiyun /** MSCS Request frame, refer section 9.4.18.6 in the spec P802.11REVmd_D3.1 */ 2593*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_mscs_req { 2594*4882a593Smuzhiyun uint8 category; /* ACTION_RAV_STREAMING (19) */ 2595*4882a593Smuzhiyun uint8 robust_action; /* action: MSCS Req (4), MSCS Res (5), etc. */ 2596*4882a593Smuzhiyun uint8 dialog_token; /* To identify the MSCS request and response */ 2597*4882a593Smuzhiyun dot11_mscs_descr_ie_t mscs_descr; /* MSCS descriptor */ 2598*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2599*4882a593Smuzhiyun typedef struct dot11_mscs_req dot11_mscs_req_t; 2600*4882a593Smuzhiyun #define DOT11_MSCS_REQ_HDR_LEN 3u /* Fixed length */ 2601*4882a593Smuzhiyun 2602*4882a593Smuzhiyun /** MSCS Response frame, refer section 9.4.18.7 in the spec P802.11REVmd_D3.1 */ 2603*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_mscs_res { 2604*4882a593Smuzhiyun uint8 category; /* ACTION_RAV_STREAMING (19) */ 2605*4882a593Smuzhiyun uint8 robust_action; /* action: MSCS Req (4), MSCS Res (5), etc. */ 2606*4882a593Smuzhiyun uint8 dialog_token; /* To identify the MSCS request and response */ 2607*4882a593Smuzhiyun uint16 status; /* status code */ 2608*4882a593Smuzhiyun uint8 data[]; /* optional MSCS descriptor */ 2609*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2610*4882a593Smuzhiyun typedef struct dot11_mscs_res dot11_mscs_res_t; 2611*4882a593Smuzhiyun #define DOT11_MSCS_RES_HDR_LEN 5u /* Fixed length */ 2612*4882a593Smuzhiyun 2613*4882a593Smuzhiyun /* MSCS subelement */ 2614*4882a593Smuzhiyun #define DOT11_MSCS_SUBELEM_ID_STATUS 1u /* MSCS subelement ID for the status */ 2615*4882a593Smuzhiyun 2616*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_mscs_subelement { 2617*4882a593Smuzhiyun uint8 id; /* MSCS specific subelement ID */ 2618*4882a593Smuzhiyun uint8 len; /* Length in bytes */ 2619*4882a593Smuzhiyun uint8 data[]; /* Subelement specific data */ 2620*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2621*4882a593Smuzhiyun typedef struct dot11_mscs_subelement dot11_mscs_subelement_t; 2622*4882a593Smuzhiyun #define DOT11_MSCS_DESCR_SUBELEM_IE_STATUS_LEN 2u /* Subelement ID status length */ 2623*4882a593Smuzhiyun 2624*4882a593Smuzhiyun /** TFS request element */ 2625*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_tfs_req_ie { 2626*4882a593Smuzhiyun uint8 id; /* 91, DOT11_MNG_TFS_REQUEST_ID */ 2627*4882a593Smuzhiyun uint8 len; 2628*4882a593Smuzhiyun uint8 tfs_id; 2629*4882a593Smuzhiyun uint8 actcode; 2630*4882a593Smuzhiyun uint8 data[1]; 2631*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2632*4882a593Smuzhiyun typedef struct dot11_tfs_req_ie dot11_tfs_req_ie_t; 2633*4882a593Smuzhiyun #define DOT11_TFS_REQ_IE_LEN 2 /* Fixed length, without id and len */ 2634*4882a593Smuzhiyun 2635*4882a593Smuzhiyun /** TFS request action codes (bitfield) */ 2636*4882a593Smuzhiyun #define DOT11_TFS_ACTCODE_DELETE 1 2637*4882a593Smuzhiyun #define DOT11_TFS_ACTCODE_NOTIFY 2 2638*4882a593Smuzhiyun 2639*4882a593Smuzhiyun /** TFS request subelement IDs */ 2640*4882a593Smuzhiyun #define DOT11_TFS_REQ_TFS_SE_ID 1 2641*4882a593Smuzhiyun #define DOT11_TFS_REQ_VENDOR_SE_ID 221 2642*4882a593Smuzhiyun 2643*4882a593Smuzhiyun /** TFS subelement */ 2644*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_tfs_se { 2645*4882a593Smuzhiyun uint8 sub_id; 2646*4882a593Smuzhiyun uint8 len; 2647*4882a593Smuzhiyun uint8 data[1]; /* TCLAS element(s) + optional TCLAS proc */ 2648*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2649*4882a593Smuzhiyun typedef struct dot11_tfs_se dot11_tfs_se_t; 2650*4882a593Smuzhiyun 2651*4882a593Smuzhiyun /** TFS response element */ 2652*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_tfs_resp_ie { 2653*4882a593Smuzhiyun uint8 id; /* 92, DOT11_MNG_TFS_RESPONSE_ID */ 2654*4882a593Smuzhiyun uint8 len; 2655*4882a593Smuzhiyun uint8 tfs_id; 2656*4882a593Smuzhiyun uint8 data[1]; 2657*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2658*4882a593Smuzhiyun typedef struct dot11_tfs_resp_ie dot11_tfs_resp_ie_t; 2659*4882a593Smuzhiyun #define DOT11_TFS_RESP_IE_LEN 1u /* Fixed length, without id and len */ 2660*4882a593Smuzhiyun 2661*4882a593Smuzhiyun /** TFS response subelement IDs (same subelments, but different IDs than in TFS request */ 2662*4882a593Smuzhiyun #define DOT11_TFS_RESP_TFS_STATUS_SE_ID 1 2663*4882a593Smuzhiyun #define DOT11_TFS_RESP_TFS_SE_ID 2 2664*4882a593Smuzhiyun #define DOT11_TFS_RESP_VENDOR_SE_ID 221 2665*4882a593Smuzhiyun 2666*4882a593Smuzhiyun /** TFS status subelement */ 2667*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_tfs_status_se { 2668*4882a593Smuzhiyun uint8 sub_id; /* 92, DOT11_MNG_TFS_RESPONSE_ID */ 2669*4882a593Smuzhiyun uint8 len; 2670*4882a593Smuzhiyun uint8 resp_st; 2671*4882a593Smuzhiyun uint8 data[1]; /* Potential dot11_tfs_se_t included */ 2672*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2673*4882a593Smuzhiyun typedef struct dot11_tfs_status_se dot11_tfs_status_se_t; 2674*4882a593Smuzhiyun #define DOT11_TFS_STATUS_SE_LEN 1 /* Fixed length, without id and len */ 2675*4882a593Smuzhiyun 2676*4882a593Smuzhiyun /* Following Definition should be merged to FMS_TFS macro below */ 2677*4882a593Smuzhiyun /* TFS Response status code. Identical to FMS Element status, without N/A */ 2678*4882a593Smuzhiyun #define DOT11_TFS_STATUS_ACCEPT 0 2679*4882a593Smuzhiyun #define DOT11_TFS_STATUS_DENY_FORMAT 1 2680*4882a593Smuzhiyun #define DOT11_TFS_STATUS_DENY_RESOURCE 2 2681*4882a593Smuzhiyun #define DOT11_TFS_STATUS_DENY_POLICY 4 2682*4882a593Smuzhiyun #define DOT11_TFS_STATUS_DENY_UNSPECIFIED 5 2683*4882a593Smuzhiyun #define DOT11_TFS_STATUS_ALTPREF_POLICY 7 2684*4882a593Smuzhiyun #define DOT11_TFS_STATUS_ALTPREF_TCLAS_UNSUPP 14 2685*4882a593Smuzhiyun 2686*4882a593Smuzhiyun /* FMS Element Status and TFS Response Status Definition */ 2687*4882a593Smuzhiyun #define DOT11_FMS_TFS_STATUS_ACCEPT 0 2688*4882a593Smuzhiyun #define DOT11_FMS_TFS_STATUS_DENY_FORMAT 1 2689*4882a593Smuzhiyun #define DOT11_FMS_TFS_STATUS_DENY_RESOURCE 2 2690*4882a593Smuzhiyun #define DOT11_FMS_TFS_STATUS_DENY_MULTIPLE_DI 3 2691*4882a593Smuzhiyun #define DOT11_FMS_TFS_STATUS_DENY_POLICY 4 2692*4882a593Smuzhiyun #define DOT11_FMS_TFS_STATUS_DENY_UNSPECIFIED 5 2693*4882a593Smuzhiyun #define DOT11_FMS_TFS_STATUS_ALT_DIFF_DI 6 2694*4882a593Smuzhiyun #define DOT11_FMS_TFS_STATUS_ALT_POLICY 7 2695*4882a593Smuzhiyun #define DOT11_FMS_TFS_STATUS_ALT_CHANGE_DI 8 2696*4882a593Smuzhiyun #define DOT11_FMS_TFS_STATUS_ALT_MCRATE 9 2697*4882a593Smuzhiyun #define DOT11_FMS_TFS_STATUS_TERM_POLICY 10 2698*4882a593Smuzhiyun #define DOT11_FMS_TFS_STATUS_TERM_RESOURCE 11 2699*4882a593Smuzhiyun #define DOT11_FMS_TFS_STATUS_TERM_HIGHER_PRIO 12 2700*4882a593Smuzhiyun #define DOT11_FMS_TFS_STATUS_ALT_CHANGE_MDI 13 2701*4882a593Smuzhiyun #define DOT11_FMS_TFS_STATUS_ALT_TCLAS_UNSUPP 14 2702*4882a593Smuzhiyun 2703*4882a593Smuzhiyun /** TFS Management Request frame header */ 2704*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_tfs_req { 2705*4882a593Smuzhiyun uint8 category; /* category of action frame (10) */ 2706*4882a593Smuzhiyun uint8 action; /* WNM action: TFS request (13) */ 2707*4882a593Smuzhiyun uint8 token; /* dialog token */ 2708*4882a593Smuzhiyun uint8 data[1]; /* Elements */ 2709*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2710*4882a593Smuzhiyun typedef struct dot11_tfs_req dot11_tfs_req_t; 2711*4882a593Smuzhiyun #define DOT11_TFS_REQ_LEN 3 /* Fixed length */ 2712*4882a593Smuzhiyun 2713*4882a593Smuzhiyun /** TFS Management Response frame header */ 2714*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_tfs_resp { 2715*4882a593Smuzhiyun uint8 category; /* category of action frame (10) */ 2716*4882a593Smuzhiyun uint8 action; /* WNM action: TFS request (14) */ 2717*4882a593Smuzhiyun uint8 token; /* dialog token */ 2718*4882a593Smuzhiyun uint8 data[1]; /* Elements */ 2719*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2720*4882a593Smuzhiyun typedef struct dot11_tfs_resp dot11_tfs_resp_t; 2721*4882a593Smuzhiyun #define DOT11_TFS_RESP_LEN 3 /* Fixed length */ 2722*4882a593Smuzhiyun 2723*4882a593Smuzhiyun /** TFS Management Notify frame request header */ 2724*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_tfs_notify_req { 2725*4882a593Smuzhiyun uint8 category; /* category of action frame (10) */ 2726*4882a593Smuzhiyun uint8 action; /* WNM action: TFS notify request (15) */ 2727*4882a593Smuzhiyun uint8 tfs_id_cnt; /* TFS IDs count */ 2728*4882a593Smuzhiyun uint8 tfs_id[1]; /* Array of TFS IDs */ 2729*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2730*4882a593Smuzhiyun typedef struct dot11_tfs_notify_req dot11_tfs_notify_req_t; 2731*4882a593Smuzhiyun #define DOT11_TFS_NOTIFY_REQ_LEN 3 /* Fixed length */ 2732*4882a593Smuzhiyun 2733*4882a593Smuzhiyun /** TFS Management Notify frame response header */ 2734*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_tfs_notify_resp { 2735*4882a593Smuzhiyun uint8 category; /* category of action frame (10) */ 2736*4882a593Smuzhiyun uint8 action; /* WNM action: TFS notify response (28) */ 2737*4882a593Smuzhiyun uint8 tfs_id_cnt; /* TFS IDs count */ 2738*4882a593Smuzhiyun uint8 tfs_id[1]; /* Array of TFS IDs */ 2739*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2740*4882a593Smuzhiyun typedef struct dot11_tfs_notify_resp dot11_tfs_notify_resp_t; 2741*4882a593Smuzhiyun #define DOT11_TFS_NOTIFY_RESP_LEN 3 /* Fixed length */ 2742*4882a593Smuzhiyun 2743*4882a593Smuzhiyun /** WNM-Sleep Management Request frame header */ 2744*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_wnm_sleep_req { 2745*4882a593Smuzhiyun uint8 category; /* category of action frame (10) */ 2746*4882a593Smuzhiyun uint8 action; /* WNM action: wnm-sleep request (16) */ 2747*4882a593Smuzhiyun uint8 token; /* dialog token */ 2748*4882a593Smuzhiyun uint8 data[1]; /* Elements */ 2749*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2750*4882a593Smuzhiyun typedef struct dot11_wnm_sleep_req dot11_wnm_sleep_req_t; 2751*4882a593Smuzhiyun #define DOT11_WNM_SLEEP_REQ_LEN 3 /* Fixed length */ 2752*4882a593Smuzhiyun 2753*4882a593Smuzhiyun /** WNM-Sleep Management Response frame header */ 2754*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_wnm_sleep_resp { 2755*4882a593Smuzhiyun uint8 category; /* category of action frame (10) */ 2756*4882a593Smuzhiyun uint8 action; /* WNM action: wnm-sleep request (17) */ 2757*4882a593Smuzhiyun uint8 token; /* dialog token */ 2758*4882a593Smuzhiyun uint16 key_len; /* key data length */ 2759*4882a593Smuzhiyun uint8 data[1]; /* Elements */ 2760*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2761*4882a593Smuzhiyun typedef struct dot11_wnm_sleep_resp dot11_wnm_sleep_resp_t; 2762*4882a593Smuzhiyun #define DOT11_WNM_SLEEP_RESP_LEN 5 /* Fixed length */ 2763*4882a593Smuzhiyun 2764*4882a593Smuzhiyun #define DOT11_WNM_SLEEP_SUBELEM_ID_GTK 0 2765*4882a593Smuzhiyun #define DOT11_WNM_SLEEP_SUBELEM_ID_IGTK 1 2766*4882a593Smuzhiyun 2767*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_wnm_sleep_subelem_gtk { 2768*4882a593Smuzhiyun uint8 sub_id; 2769*4882a593Smuzhiyun uint8 len; 2770*4882a593Smuzhiyun uint16 key_info; 2771*4882a593Smuzhiyun uint8 key_length; 2772*4882a593Smuzhiyun uint8 rsc[8]; 2773*4882a593Smuzhiyun uint8 key[1]; 2774*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2775*4882a593Smuzhiyun typedef struct dot11_wnm_sleep_subelem_gtk dot11_wnm_sleep_subelem_gtk_t; 2776*4882a593Smuzhiyun #define DOT11_WNM_SLEEP_SUBELEM_GTK_FIXED_LEN 11 /* without sub_id, len, and key */ 2777*4882a593Smuzhiyun #define DOT11_WNM_SLEEP_SUBELEM_GTK_MAX_LEN 43 /* without sub_id and len */ 2778*4882a593Smuzhiyun 2779*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_wnm_sleep_subelem_igtk { 2780*4882a593Smuzhiyun uint8 sub_id; 2781*4882a593Smuzhiyun uint8 len; 2782*4882a593Smuzhiyun uint16 key_id; 2783*4882a593Smuzhiyun uint8 pn[6]; 2784*4882a593Smuzhiyun uint8 key[16]; 2785*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2786*4882a593Smuzhiyun typedef struct dot11_wnm_sleep_subelem_igtk dot11_wnm_sleep_subelem_igtk_t; 2787*4882a593Smuzhiyun #define DOT11_WNM_SLEEP_SUBELEM_IGTK_LEN 24 /* Fixed length */ 2788*4882a593Smuzhiyun 2789*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_wnm_sleep_ie { 2790*4882a593Smuzhiyun uint8 id; /* 93, DOT11_MNG_WNM_SLEEP_MODE_ID */ 2791*4882a593Smuzhiyun uint8 len; 2792*4882a593Smuzhiyun uint8 act_type; 2793*4882a593Smuzhiyun uint8 resp_status; 2794*4882a593Smuzhiyun uint16 interval; 2795*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2796*4882a593Smuzhiyun typedef struct dot11_wnm_sleep_ie dot11_wnm_sleep_ie_t; 2797*4882a593Smuzhiyun #define DOT11_WNM_SLEEP_IE_LEN 4 /* Fixed length */ 2798*4882a593Smuzhiyun 2799*4882a593Smuzhiyun #define DOT11_WNM_SLEEP_ACT_TYPE_ENTER 0 2800*4882a593Smuzhiyun #define DOT11_WNM_SLEEP_ACT_TYPE_EXIT 1 2801*4882a593Smuzhiyun 2802*4882a593Smuzhiyun #define DOT11_WNM_SLEEP_RESP_ACCEPT 0 2803*4882a593Smuzhiyun #define DOT11_WNM_SLEEP_RESP_UPDATE 1 2804*4882a593Smuzhiyun #define DOT11_WNM_SLEEP_RESP_DENY 2 2805*4882a593Smuzhiyun #define DOT11_WNM_SLEEP_RESP_DENY_TEMP 3 2806*4882a593Smuzhiyun #define DOT11_WNM_SLEEP_RESP_DENY_KEY 4 2807*4882a593Smuzhiyun #define DOT11_WNM_SLEEP_RESP_DENY_INUSE 5 2808*4882a593Smuzhiyun #define DOT11_WNM_SLEEP_RESP_LAST 6 2809*4882a593Smuzhiyun 2810*4882a593Smuzhiyun /** DMS Management Request frame header */ 2811*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_dms_req { 2812*4882a593Smuzhiyun uint8 category; /* category of action frame (10) */ 2813*4882a593Smuzhiyun uint8 action; /* WNM action: dms request (23) */ 2814*4882a593Smuzhiyun uint8 token; /* dialog token */ 2815*4882a593Smuzhiyun uint8 data[1]; /* Elements */ 2816*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2817*4882a593Smuzhiyun typedef struct dot11_dms_req dot11_dms_req_t; 2818*4882a593Smuzhiyun #define DOT11_DMS_REQ_LEN 3 /* Fixed length */ 2819*4882a593Smuzhiyun 2820*4882a593Smuzhiyun /** DMS Management Response frame header */ 2821*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_dms_resp { 2822*4882a593Smuzhiyun uint8 category; /* category of action frame (10) */ 2823*4882a593Smuzhiyun uint8 action; /* WNM action: dms request (24) */ 2824*4882a593Smuzhiyun uint8 token; /* dialog token */ 2825*4882a593Smuzhiyun uint8 data[1]; /* Elements */ 2826*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2827*4882a593Smuzhiyun typedef struct dot11_dms_resp dot11_dms_resp_t; 2828*4882a593Smuzhiyun #define DOT11_DMS_RESP_LEN 3 /* Fixed length */ 2829*4882a593Smuzhiyun 2830*4882a593Smuzhiyun /** DMS request element */ 2831*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_dms_req_ie { 2832*4882a593Smuzhiyun uint8 id; /* 99, DOT11_MNG_DMS_REQUEST_ID */ 2833*4882a593Smuzhiyun uint8 len; 2834*4882a593Smuzhiyun uint8 data[1]; 2835*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2836*4882a593Smuzhiyun typedef struct dot11_dms_req_ie dot11_dms_req_ie_t; 2837*4882a593Smuzhiyun #define DOT11_DMS_REQ_IE_LEN 2 /* Fixed length */ 2838*4882a593Smuzhiyun 2839*4882a593Smuzhiyun /** DMS response element */ 2840*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_dms_resp_ie { 2841*4882a593Smuzhiyun uint8 id; /* 100, DOT11_MNG_DMS_RESPONSE_ID */ 2842*4882a593Smuzhiyun uint8 len; 2843*4882a593Smuzhiyun uint8 data[1]; 2844*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2845*4882a593Smuzhiyun typedef struct dot11_dms_resp_ie dot11_dms_resp_ie_t; 2846*4882a593Smuzhiyun #define DOT11_DMS_RESP_IE_LEN 2 /* Fixed length */ 2847*4882a593Smuzhiyun 2848*4882a593Smuzhiyun /** DMS request descriptor */ 2849*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_dms_req_desc { 2850*4882a593Smuzhiyun uint8 dms_id; 2851*4882a593Smuzhiyun uint8 len; 2852*4882a593Smuzhiyun uint8 type; 2853*4882a593Smuzhiyun uint8 data[1]; 2854*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2855*4882a593Smuzhiyun typedef struct dot11_dms_req_desc dot11_dms_req_desc_t; 2856*4882a593Smuzhiyun #define DOT11_DMS_REQ_DESC_LEN 3 /* Fixed length */ 2857*4882a593Smuzhiyun 2858*4882a593Smuzhiyun #define DOT11_DMS_REQ_TYPE_ADD 0 2859*4882a593Smuzhiyun #define DOT11_DMS_REQ_TYPE_REMOVE 1 2860*4882a593Smuzhiyun #define DOT11_DMS_REQ_TYPE_CHANGE 2 2861*4882a593Smuzhiyun 2862*4882a593Smuzhiyun /** DMS response status */ 2863*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_dms_resp_st { 2864*4882a593Smuzhiyun uint8 dms_id; 2865*4882a593Smuzhiyun uint8 len; 2866*4882a593Smuzhiyun uint8 type; 2867*4882a593Smuzhiyun uint16 lsc; 2868*4882a593Smuzhiyun uint8 data[1]; 2869*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2870*4882a593Smuzhiyun typedef struct dot11_dms_resp_st dot11_dms_resp_st_t; 2871*4882a593Smuzhiyun #define DOT11_DMS_RESP_STATUS_LEN 5 /* Fixed length */ 2872*4882a593Smuzhiyun 2873*4882a593Smuzhiyun #define DOT11_DMS_RESP_TYPE_ACCEPT 0 2874*4882a593Smuzhiyun #define DOT11_DMS_RESP_TYPE_DENY 1 2875*4882a593Smuzhiyun #define DOT11_DMS_RESP_TYPE_TERM 2 2876*4882a593Smuzhiyun 2877*4882a593Smuzhiyun #define DOT11_DMS_RESP_LSC_UNSUPPORTED 0xFFFF 2878*4882a593Smuzhiyun 2879*4882a593Smuzhiyun /** WNM-Notification Request frame header */ 2880*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_wnm_notif_req { 2881*4882a593Smuzhiyun uint8 category; /* category of action frame (10) */ 2882*4882a593Smuzhiyun uint8 action; /* WNM action: Notification request (26) */ 2883*4882a593Smuzhiyun uint8 token; /* dialog token */ 2884*4882a593Smuzhiyun uint8 type; /* type */ 2885*4882a593Smuzhiyun uint8 data[1]; /* Sub-elements */ 2886*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2887*4882a593Smuzhiyun typedef struct dot11_wnm_notif_req dot11_wnm_notif_req_t; 2888*4882a593Smuzhiyun #define DOT11_WNM_NOTIF_REQ_LEN 4 /* Fixed length */ 2889*4882a593Smuzhiyun 2890*4882a593Smuzhiyun /** FMS Management Request frame header */ 2891*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_fms_req { 2892*4882a593Smuzhiyun uint8 category; /* category of action frame (10) */ 2893*4882a593Smuzhiyun uint8 action; /* WNM action: fms request (9) */ 2894*4882a593Smuzhiyun uint8 token; /* dialog token */ 2895*4882a593Smuzhiyun uint8 data[1]; /* Elements */ 2896*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2897*4882a593Smuzhiyun typedef struct dot11_fms_req dot11_fms_req_t; 2898*4882a593Smuzhiyun #define DOT11_FMS_REQ_LEN 3 /* Fixed length */ 2899*4882a593Smuzhiyun 2900*4882a593Smuzhiyun /** FMS Management Response frame header */ 2901*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_fms_resp { 2902*4882a593Smuzhiyun uint8 category; /* category of action frame (10) */ 2903*4882a593Smuzhiyun uint8 action; /* WNM action: fms request (10) */ 2904*4882a593Smuzhiyun uint8 token; /* dialog token */ 2905*4882a593Smuzhiyun uint8 data[1]; /* Elements */ 2906*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2907*4882a593Smuzhiyun typedef struct dot11_fms_resp dot11_fms_resp_t; 2908*4882a593Smuzhiyun #define DOT11_FMS_RESP_LEN 3 /* Fixed length */ 2909*4882a593Smuzhiyun 2910*4882a593Smuzhiyun /** FMS Descriptor element */ 2911*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_fms_desc { 2912*4882a593Smuzhiyun uint8 id; 2913*4882a593Smuzhiyun uint8 len; 2914*4882a593Smuzhiyun uint8 num_fms_cnt; 2915*4882a593Smuzhiyun uint8 data[1]; 2916*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2917*4882a593Smuzhiyun typedef struct dot11_fms_desc dot11_fms_desc_t; 2918*4882a593Smuzhiyun #define DOT11_FMS_DESC_LEN 1 /* Fixed length */ 2919*4882a593Smuzhiyun 2920*4882a593Smuzhiyun #define DOT11_FMS_CNTR_MAX 0x8 2921*4882a593Smuzhiyun #define DOT11_FMS_CNTR_ID_MASK 0x7 2922*4882a593Smuzhiyun #define DOT11_FMS_CNTR_ID_SHIFT 0x0 2923*4882a593Smuzhiyun #define DOT11_FMS_CNTR_COUNT_MASK 0xf1 2924*4882a593Smuzhiyun #define DOT11_FMS_CNTR_SHIFT 0x3 2925*4882a593Smuzhiyun 2926*4882a593Smuzhiyun /** FMS request element */ 2927*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_fms_req_ie { 2928*4882a593Smuzhiyun uint8 id; 2929*4882a593Smuzhiyun uint8 len; 2930*4882a593Smuzhiyun uint8 fms_token; /* token used to identify fms stream set */ 2931*4882a593Smuzhiyun uint8 data[1]; 2932*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2933*4882a593Smuzhiyun typedef struct dot11_fms_req_ie dot11_fms_req_ie_t; 2934*4882a593Smuzhiyun #define DOT11_FMS_REQ_IE_FIX_LEN 1 /* Fixed length */ 2935*4882a593Smuzhiyun 2936*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rate_id_field { 2937*4882a593Smuzhiyun uint8 mask; 2938*4882a593Smuzhiyun uint8 mcs_idx; 2939*4882a593Smuzhiyun uint16 rate; 2940*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2941*4882a593Smuzhiyun typedef struct dot11_rate_id_field dot11_rate_id_field_t; 2942*4882a593Smuzhiyun #define DOT11_RATE_ID_FIELD_MCS_SEL_MASK 0x7 2943*4882a593Smuzhiyun #define DOT11_RATE_ID_FIELD_MCS_SEL_OFFSET 0 2944*4882a593Smuzhiyun #define DOT11_RATE_ID_FIELD_RATETYPE_MASK 0x18 2945*4882a593Smuzhiyun #define DOT11_RATE_ID_FIELD_RATETYPE_OFFSET 3 2946*4882a593Smuzhiyun #define DOT11_RATE_ID_FIELD_LEN sizeof(dot11_rate_id_field_t) 2947*4882a593Smuzhiyun 2948*4882a593Smuzhiyun /** FMS request subelements */ 2949*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_fms_se { 2950*4882a593Smuzhiyun uint8 sub_id; 2951*4882a593Smuzhiyun uint8 len; 2952*4882a593Smuzhiyun uint8 interval; 2953*4882a593Smuzhiyun uint8 max_interval; 2954*4882a593Smuzhiyun dot11_rate_id_field_t rate; 2955*4882a593Smuzhiyun uint8 data[1]; 2956*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2957*4882a593Smuzhiyun typedef struct dot11_fms_se dot11_fms_se_t; 2958*4882a593Smuzhiyun #define DOT11_FMS_REQ_SE_LEN 6 /* Fixed length */ 2959*4882a593Smuzhiyun 2960*4882a593Smuzhiyun #define DOT11_FMS_REQ_SE_ID_FMS 1 /* FMS subelement */ 2961*4882a593Smuzhiyun #define DOT11_FMS_REQ_SE_ID_VS 221 /* Vendor Specific subelement */ 2962*4882a593Smuzhiyun 2963*4882a593Smuzhiyun /** FMS response element */ 2964*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_fms_resp_ie { 2965*4882a593Smuzhiyun uint8 id; 2966*4882a593Smuzhiyun uint8 len; 2967*4882a593Smuzhiyun uint8 fms_token; 2968*4882a593Smuzhiyun uint8 data[1]; 2969*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2970*4882a593Smuzhiyun typedef struct dot11_fms_resp_ie dot11_fms_resp_ie_t; 2971*4882a593Smuzhiyun #define DOT11_FMS_RESP_IE_FIX_LEN 1 /* Fixed length */ 2972*4882a593Smuzhiyun 2973*4882a593Smuzhiyun /* FMS status subelements */ 2974*4882a593Smuzhiyun #define DOT11_FMS_STATUS_SE_ID_FMS 1 /* FMS Status */ 2975*4882a593Smuzhiyun #define DOT11_FMS_STATUS_SE_ID_TCLAS 2 /* TCLAS Status */ 2976*4882a593Smuzhiyun #define DOT11_FMS_STATUS_SE_ID_VS 221 /* Vendor Specific subelement */ 2977*4882a593Smuzhiyun 2978*4882a593Smuzhiyun /** FMS status subelement */ 2979*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_fms_status_se { 2980*4882a593Smuzhiyun uint8 sub_id; 2981*4882a593Smuzhiyun uint8 len; 2982*4882a593Smuzhiyun uint8 status; 2983*4882a593Smuzhiyun uint8 interval; 2984*4882a593Smuzhiyun uint8 max_interval; 2985*4882a593Smuzhiyun uint8 fmsid; 2986*4882a593Smuzhiyun uint8 counter; 2987*4882a593Smuzhiyun dot11_rate_id_field_t rate; 2988*4882a593Smuzhiyun uint8 mcast_addr[ETHER_ADDR_LEN]; 2989*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 2990*4882a593Smuzhiyun typedef struct dot11_fms_status_se dot11_fms_status_se_t; 2991*4882a593Smuzhiyun #define DOT11_FMS_STATUS_SE_LEN 15 /* Fixed length */ 2992*4882a593Smuzhiyun 2993*4882a593Smuzhiyun /** TCLAS status subelement */ 2994*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_tclas_status_se { 2995*4882a593Smuzhiyun uint8 sub_id; 2996*4882a593Smuzhiyun uint8 len; 2997*4882a593Smuzhiyun uint8 fmsid; 2998*4882a593Smuzhiyun uint8 data[1]; 2999*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3000*4882a593Smuzhiyun typedef struct dot11_tclas_status_se dot11_tclas_status_se_t; 3001*4882a593Smuzhiyun #define DOT11_TCLAS_STATUS_SE_LEN 1 /* Fixed length */ 3002*4882a593Smuzhiyun 3003*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_addba_req { 3004*4882a593Smuzhiyun uint8 category; /* category of action frame (3) */ 3005*4882a593Smuzhiyun uint8 action; /* action: addba req */ 3006*4882a593Smuzhiyun uint8 token; /* identifier */ 3007*4882a593Smuzhiyun uint16 addba_param_set; /* parameter set */ 3008*4882a593Smuzhiyun uint16 timeout; /* timeout in seconds */ 3009*4882a593Smuzhiyun uint16 start_seqnum; /* starting sequence number */ 3010*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3011*4882a593Smuzhiyun typedef struct dot11_addba_req dot11_addba_req_t; 3012*4882a593Smuzhiyun #define DOT11_ADDBA_REQ_LEN 9 /* length of addba req frame */ 3013*4882a593Smuzhiyun 3014*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_addba_resp { 3015*4882a593Smuzhiyun uint8 category; /* category of action frame (3) */ 3016*4882a593Smuzhiyun uint8 action; /* action: addba resp */ 3017*4882a593Smuzhiyun uint8 token; /* identifier */ 3018*4882a593Smuzhiyun uint16 status; /* status of add request */ 3019*4882a593Smuzhiyun uint16 addba_param_set; /* negotiated parameter set */ 3020*4882a593Smuzhiyun uint16 timeout; /* negotiated timeout in seconds */ 3021*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3022*4882a593Smuzhiyun typedef struct dot11_addba_resp dot11_addba_resp_t; 3023*4882a593Smuzhiyun #define DOT11_ADDBA_RESP_LEN 9 /* length of addba resp frame */ 3024*4882a593Smuzhiyun 3025*4882a593Smuzhiyun /* DELBA action parameters */ 3026*4882a593Smuzhiyun #define DOT11_DELBA_PARAM_INIT_MASK 0x0800 /* initiator mask */ 3027*4882a593Smuzhiyun #define DOT11_DELBA_PARAM_INIT_SHIFT 11 /* initiator shift */ 3028*4882a593Smuzhiyun #define DOT11_DELBA_PARAM_TID_MASK 0xf000 /* tid mask */ 3029*4882a593Smuzhiyun #define DOT11_DELBA_PARAM_TID_SHIFT 12 /* tid shift */ 3030*4882a593Smuzhiyun 3031*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_delba { 3032*4882a593Smuzhiyun uint8 category; /* category of action frame (3) */ 3033*4882a593Smuzhiyun uint8 action; /* action: addba req */ 3034*4882a593Smuzhiyun uint16 delba_param_set; /* paarmeter set */ 3035*4882a593Smuzhiyun uint16 reason; /* reason for dellba */ 3036*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3037*4882a593Smuzhiyun typedef struct dot11_delba dot11_delba_t; 3038*4882a593Smuzhiyun #define DOT11_DELBA_LEN 6 /* length of delba frame */ 3039*4882a593Smuzhiyun 3040*4882a593Smuzhiyun /* SA Query action field value */ 3041*4882a593Smuzhiyun #define SA_QUERY_REQUEST 0 3042*4882a593Smuzhiyun #define SA_QUERY_RESPONSE 1 3043*4882a593Smuzhiyun 3044*4882a593Smuzhiyun /* ************* 802.11r related definitions. ************* */ 3045*4882a593Smuzhiyun 3046*4882a593Smuzhiyun /** Over-the-DS Fast Transition Request frame header */ 3047*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ft_req { 3048*4882a593Smuzhiyun uint8 category; /* category of action frame (6) */ 3049*4882a593Smuzhiyun uint8 action; /* action: ft req */ 3050*4882a593Smuzhiyun uint8 sta_addr[ETHER_ADDR_LEN]; 3051*4882a593Smuzhiyun uint8 tgt_ap_addr[ETHER_ADDR_LEN]; 3052*4882a593Smuzhiyun uint8 data[1]; /* Elements */ 3053*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3054*4882a593Smuzhiyun typedef struct dot11_ft_req dot11_ft_req_t; 3055*4882a593Smuzhiyun #define DOT11_FT_REQ_FIXED_LEN 14 3056*4882a593Smuzhiyun 3057*4882a593Smuzhiyun /** Over-the-DS Fast Transition Response frame header */ 3058*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ft_res { 3059*4882a593Smuzhiyun uint8 category; /* category of action frame (6) */ 3060*4882a593Smuzhiyun uint8 action; /* action: ft resp */ 3061*4882a593Smuzhiyun uint8 sta_addr[ETHER_ADDR_LEN]; 3062*4882a593Smuzhiyun uint8 tgt_ap_addr[ETHER_ADDR_LEN]; 3063*4882a593Smuzhiyun uint16 status; /* status code */ 3064*4882a593Smuzhiyun uint8 data[1]; /* Elements */ 3065*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3066*4882a593Smuzhiyun typedef struct dot11_ft_res dot11_ft_res_t; 3067*4882a593Smuzhiyun #define DOT11_FT_RES_FIXED_LEN 16 3068*4882a593Smuzhiyun 3069*4882a593Smuzhiyun /** RDE RIC Data Element. */ 3070*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rde_ie { 3071*4882a593Smuzhiyun uint8 id; /* 11r, DOT11_MNG_RDE_ID */ 3072*4882a593Smuzhiyun uint8 length; 3073*4882a593Smuzhiyun uint8 rde_id; /* RDE identifier. */ 3074*4882a593Smuzhiyun uint8 rd_count; /* Resource Descriptor Count. */ 3075*4882a593Smuzhiyun uint16 status; /* Status Code. */ 3076*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3077*4882a593Smuzhiyun typedef struct dot11_rde_ie dot11_rde_ie_t; 3078*4882a593Smuzhiyun 3079*4882a593Smuzhiyun /* 11r - Size of the RDE (RIC Data Element) IE, including TLV header. */ 3080*4882a593Smuzhiyun #define DOT11_MNG_RDE_IE_LEN sizeof(dot11_rde_ie_t) 3081*4882a593Smuzhiyun 3082*4882a593Smuzhiyun /* ************* 802.11k related definitions. ************* */ 3083*4882a593Smuzhiyun 3084*4882a593Smuzhiyun /* Radio measurements enabled capability ie */ 3085*4882a593Smuzhiyun #define DOT11_RRM_CAP_LEN 5 /* length of rrm cap bitmap */ 3086*4882a593Smuzhiyun #define RCPI_IE_LEN 1 3087*4882a593Smuzhiyun #define RSNI_IE_LEN 1 3088*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rrm_cap_ie { 3089*4882a593Smuzhiyun uint8 cap[DOT11_RRM_CAP_LEN]; 3090*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3091*4882a593Smuzhiyun typedef struct dot11_rrm_cap_ie dot11_rrm_cap_ie_t; 3092*4882a593Smuzhiyun 3093*4882a593Smuzhiyun /* Bitmap definitions for cap ie */ 3094*4882a593Smuzhiyun #define DOT11_RRM_CAP_LINK 0 3095*4882a593Smuzhiyun #define DOT11_RRM_CAP_NEIGHBOR_REPORT 1 3096*4882a593Smuzhiyun #define DOT11_RRM_CAP_PARALLEL 2 3097*4882a593Smuzhiyun #define DOT11_RRM_CAP_REPEATED 3 3098*4882a593Smuzhiyun #define DOT11_RRM_CAP_BCN_PASSIVE 4 3099*4882a593Smuzhiyun #define DOT11_RRM_CAP_BCN_ACTIVE 5 3100*4882a593Smuzhiyun #define DOT11_RRM_CAP_BCN_TABLE 6 3101*4882a593Smuzhiyun #define DOT11_RRM_CAP_BCN_REP_COND 7 3102*4882a593Smuzhiyun #define DOT11_RRM_CAP_FM 8 3103*4882a593Smuzhiyun #define DOT11_RRM_CAP_CLM 9 3104*4882a593Smuzhiyun #define DOT11_RRM_CAP_NHM 10 3105*4882a593Smuzhiyun #define DOT11_RRM_CAP_SM 11 3106*4882a593Smuzhiyun #define DOT11_RRM_CAP_LCIM 12 3107*4882a593Smuzhiyun #define DOT11_RRM_CAP_LCIA 13 3108*4882a593Smuzhiyun #define DOT11_RRM_CAP_TSCM 14 3109*4882a593Smuzhiyun #define DOT11_RRM_CAP_TTSCM 15 3110*4882a593Smuzhiyun #define DOT11_RRM_CAP_AP_CHANREP 16 3111*4882a593Smuzhiyun #define DOT11_RRM_CAP_RMMIB 17 3112*4882a593Smuzhiyun /* bit18-bit23, not used for RRM_IOVAR */ 3113*4882a593Smuzhiyun #define DOT11_RRM_CAP_MPC0 24 3114*4882a593Smuzhiyun #define DOT11_RRM_CAP_MPC1 25 3115*4882a593Smuzhiyun #define DOT11_RRM_CAP_MPC2 26 3116*4882a593Smuzhiyun #define DOT11_RRM_CAP_MPTI 27 3117*4882a593Smuzhiyun #define DOT11_RRM_CAP_NBRTSFO 28 3118*4882a593Smuzhiyun #define DOT11_RRM_CAP_RCPI 29 3119*4882a593Smuzhiyun #define DOT11_RRM_CAP_RSNI 30 3120*4882a593Smuzhiyun #define DOT11_RRM_CAP_BSSAAD 31 3121*4882a593Smuzhiyun #define DOT11_RRM_CAP_BSSAAC 32 3122*4882a593Smuzhiyun #define DOT11_RRM_CAP_AI 33 3123*4882a593Smuzhiyun #define DOT11_RRM_CAP_FTM_RANGE 34 3124*4882a593Smuzhiyun #define DOT11_RRM_CAP_CIVIC_LOC 35 3125*4882a593Smuzhiyun #define DOT11_RRM_CAP_IDENT_LOC 36 3126*4882a593Smuzhiyun #define DOT11_RRM_CAP_LAST 36 3127*4882a593Smuzhiyun 3128*4882a593Smuzhiyun #ifdef WL11K_ALL_MEAS 3129*4882a593Smuzhiyun #define DOT11_RRM_CAP_LINK_ENAB (1 << DOT11_RRM_CAP_LINK) 3130*4882a593Smuzhiyun #define DOT11_RRM_CAP_FM_ENAB (1 << (DOT11_RRM_CAP_FM - 8)) 3131*4882a593Smuzhiyun #define DOT11_RRM_CAP_CLM_ENAB (1 << (DOT11_RRM_CAP_CLM - 8)) 3132*4882a593Smuzhiyun #define DOT11_RRM_CAP_NHM_ENAB (1 << (DOT11_RRM_CAP_NHM - 8)) 3133*4882a593Smuzhiyun #define DOT11_RRM_CAP_SM_ENAB (1 << (DOT11_RRM_CAP_SM - 8)) 3134*4882a593Smuzhiyun #define DOT11_RRM_CAP_LCIM_ENAB (1 << (DOT11_RRM_CAP_LCIM - 8)) 3135*4882a593Smuzhiyun #define DOT11_RRM_CAP_TSCM_ENAB (1 << (DOT11_RRM_CAP_TSCM - 8)) 3136*4882a593Smuzhiyun #ifdef WL11K_AP 3137*4882a593Smuzhiyun #define DOT11_RRM_CAP_MPC0_ENAB (1 << (DOT11_RRM_CAP_MPC0 - 24)) 3138*4882a593Smuzhiyun #define DOT11_RRM_CAP_MPC1_ENAB (1 << (DOT11_RRM_CAP_MPC1 - 24)) 3139*4882a593Smuzhiyun #define DOT11_RRM_CAP_MPC2_ENAB (1 << (DOT11_RRM_CAP_MPC2 - 24)) 3140*4882a593Smuzhiyun #define DOT11_RRM_CAP_MPTI_ENAB (1 << (DOT11_RRM_CAP_MPTI - 24)) 3141*4882a593Smuzhiyun #else 3142*4882a593Smuzhiyun #define DOT11_RRM_CAP_MPC0_ENAB 0 3143*4882a593Smuzhiyun #define DOT11_RRM_CAP_MPC1_ENAB 0 3144*4882a593Smuzhiyun #define DOT11_RRM_CAP_MPC2_ENAB 0 3145*4882a593Smuzhiyun #define DOT11_RRM_CAP_MPTI_ENAB 0 3146*4882a593Smuzhiyun #endif /* WL11K_AP */ 3147*4882a593Smuzhiyun #define DOT11_RRM_CAP_CIVIC_LOC_ENAB (1 << (DOT11_RRM_CAP_CIVIC_LOC - 32)) 3148*4882a593Smuzhiyun #define DOT11_RRM_CAP_IDENT_LOC_ENAB (1 << (DOT11_RRM_CAP_IDENT_LOC - 32)) 3149*4882a593Smuzhiyun #else 3150*4882a593Smuzhiyun #define DOT11_RRM_CAP_LINK_ENAB 0 3151*4882a593Smuzhiyun #define DOT11_RRM_CAP_FM_ENAB 0 3152*4882a593Smuzhiyun #define DOT11_RRM_CAP_CLM_ENAB 0 3153*4882a593Smuzhiyun #define DOT11_RRM_CAP_NHM_ENAB 0 3154*4882a593Smuzhiyun #define DOT11_RRM_CAP_SM_ENAB 0 3155*4882a593Smuzhiyun #define DOT11_RRM_CAP_LCIM_ENAB 0 3156*4882a593Smuzhiyun #define DOT11_RRM_CAP_TSCM_ENAB 0 3157*4882a593Smuzhiyun #define DOT11_RRM_CAP_MPC0_ENAB 0 3158*4882a593Smuzhiyun #define DOT11_RRM_CAP_MPC1_ENAB 0 3159*4882a593Smuzhiyun #define DOT11_RRM_CAP_MPC2_ENAB 0 3160*4882a593Smuzhiyun #define DOT11_RRM_CAP_MPTI_ENAB 0 3161*4882a593Smuzhiyun #define DOT11_RRM_CAP_CIVIC_LOC_ENAB 0 3162*4882a593Smuzhiyun #define DOT11_RRM_CAP_IDENT_LOC_ENAB 0 3163*4882a593Smuzhiyun #endif /* WL11K_ALL_MEAS */ 3164*4882a593Smuzhiyun #ifdef WL11K_NBR_MEAS 3165*4882a593Smuzhiyun #define DOT11_RRM_CAP_NEIGHBOR_REPORT_ENAB (1 << DOT11_RRM_CAP_NEIGHBOR_REPORT) 3166*4882a593Smuzhiyun #else 3167*4882a593Smuzhiyun #define DOT11_RRM_CAP_NEIGHBOR_REPORT_ENAB 0 3168*4882a593Smuzhiyun #endif /* WL11K_NBR_MEAS */ 3169*4882a593Smuzhiyun #ifdef WL11K_BCN_MEAS 3170*4882a593Smuzhiyun #define DOT11_RRM_CAP_BCN_PASSIVE_ENAB (1 << DOT11_RRM_CAP_BCN_PASSIVE) 3171*4882a593Smuzhiyun #define DOT11_RRM_CAP_BCN_ACTIVE_ENAB (1 << DOT11_RRM_CAP_BCN_ACTIVE) 3172*4882a593Smuzhiyun #else 3173*4882a593Smuzhiyun #define DOT11_RRM_CAP_BCN_PASSIVE_ENAB 0 3174*4882a593Smuzhiyun #define DOT11_RRM_CAP_BCN_ACTIVE_ENAB 0 3175*4882a593Smuzhiyun #endif /* WL11K_BCN_MEAS */ 3176*4882a593Smuzhiyun #define DOT11_RRM_CAP_MPA_MASK 0x7 3177*4882a593Smuzhiyun /* Operating Class (formerly "Regulatory Class") definitions */ 3178*4882a593Smuzhiyun #define DOT11_OP_CLASS_NONE 255 3179*4882a593Smuzhiyun 3180*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct do11_ap_chrep { 3181*4882a593Smuzhiyun uint8 id; 3182*4882a593Smuzhiyun uint8 len; 3183*4882a593Smuzhiyun uint8 reg; 3184*4882a593Smuzhiyun uint8 chanlist[1]; 3185*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3186*4882a593Smuzhiyun typedef struct do11_ap_chrep dot11_ap_chrep_t; 3187*4882a593Smuzhiyun 3188*4882a593Smuzhiyun /* Radio Measurements action ids */ 3189*4882a593Smuzhiyun #define DOT11_RM_ACTION_RM_REQ 0 /* Radio measurement request */ 3190*4882a593Smuzhiyun #define DOT11_RM_ACTION_RM_REP 1 /* Radio measurement report */ 3191*4882a593Smuzhiyun #define DOT11_RM_ACTION_LM_REQ 2 /* Link measurement request */ 3192*4882a593Smuzhiyun #define DOT11_RM_ACTION_LM_REP 3 /* Link measurement report */ 3193*4882a593Smuzhiyun #define DOT11_RM_ACTION_NR_REQ 4 /* Neighbor report request */ 3194*4882a593Smuzhiyun #define DOT11_RM_ACTION_NR_REP 5 /* Neighbor report response */ 3195*4882a593Smuzhiyun #define DOT11_PUB_ACTION_MP 7 /* Measurement Pilot public action id */ 3196*4882a593Smuzhiyun 3197*4882a593Smuzhiyun /** Generic radio measurement action frame header */ 3198*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rm_action { 3199*4882a593Smuzhiyun uint8 category; /* category of action frame (5) */ 3200*4882a593Smuzhiyun uint8 action; /* radio measurement action */ 3201*4882a593Smuzhiyun uint8 token; /* dialog token */ 3202*4882a593Smuzhiyun uint8 data[1]; 3203*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3204*4882a593Smuzhiyun typedef struct dot11_rm_action dot11_rm_action_t; 3205*4882a593Smuzhiyun #define DOT11_RM_ACTION_LEN 3 3206*4882a593Smuzhiyun 3207*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmreq { 3208*4882a593Smuzhiyun uint8 category; /* category of action frame (5) */ 3209*4882a593Smuzhiyun uint8 action; /* radio measurement action */ 3210*4882a593Smuzhiyun uint8 token; /* dialog token */ 3211*4882a593Smuzhiyun uint16 reps; /* no. of repetitions */ 3212*4882a593Smuzhiyun uint8 data[1]; 3213*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3214*4882a593Smuzhiyun typedef struct dot11_rmreq dot11_rmreq_t; 3215*4882a593Smuzhiyun #define DOT11_RMREQ_LEN 5 3216*4882a593Smuzhiyun 3217*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rm_ie { 3218*4882a593Smuzhiyun uint8 id; 3219*4882a593Smuzhiyun uint8 len; 3220*4882a593Smuzhiyun uint8 token; 3221*4882a593Smuzhiyun uint8 mode; 3222*4882a593Smuzhiyun uint8 type; 3223*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3224*4882a593Smuzhiyun typedef struct dot11_rm_ie dot11_rm_ie_t; 3225*4882a593Smuzhiyun #define DOT11_RM_IE_LEN 5 3226*4882a593Smuzhiyun 3227*4882a593Smuzhiyun /* Definitions for "mode" bits in rm req */ 3228*4882a593Smuzhiyun #define DOT11_RMREQ_MODE_PARALLEL 1 3229*4882a593Smuzhiyun #define DOT11_RMREQ_MODE_ENABLE 2 3230*4882a593Smuzhiyun #define DOT11_RMREQ_MODE_REQUEST 4 3231*4882a593Smuzhiyun #define DOT11_RMREQ_MODE_REPORT 8 3232*4882a593Smuzhiyun #define DOT11_RMREQ_MODE_DURMAND 0x10 /* Duration Mandatory */ 3233*4882a593Smuzhiyun 3234*4882a593Smuzhiyun /* Definitions for "mode" bits in rm rep */ 3235*4882a593Smuzhiyun #define DOT11_RMREP_MODE_LATE 1 3236*4882a593Smuzhiyun #define DOT11_RMREP_MODE_INCAPABLE 2 3237*4882a593Smuzhiyun #define DOT11_RMREP_MODE_REFUSED 4 3238*4882a593Smuzhiyun 3239*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmreq_bcn { 3240*4882a593Smuzhiyun uint8 id; /* use dot11_rm_ie_t ? */ 3241*4882a593Smuzhiyun uint8 len; 3242*4882a593Smuzhiyun uint8 token; 3243*4882a593Smuzhiyun uint8 mode; 3244*4882a593Smuzhiyun uint8 type; 3245*4882a593Smuzhiyun uint8 reg; 3246*4882a593Smuzhiyun uint8 channel; 3247*4882a593Smuzhiyun uint16 interval; 3248*4882a593Smuzhiyun uint16 duration; 3249*4882a593Smuzhiyun uint8 bcn_mode; 3250*4882a593Smuzhiyun struct ether_addr bssid; 3251*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3252*4882a593Smuzhiyun typedef struct dot11_rmreq_bcn dot11_rmreq_bcn_t; 3253*4882a593Smuzhiyun #define DOT11_RMREQ_BCN_LEN 18u 3254*4882a593Smuzhiyun 3255*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmrep_bcn { 3256*4882a593Smuzhiyun uint8 reg; 3257*4882a593Smuzhiyun uint8 channel; 3258*4882a593Smuzhiyun uint32 starttime[2]; 3259*4882a593Smuzhiyun uint16 duration; 3260*4882a593Smuzhiyun uint8 frame_info; 3261*4882a593Smuzhiyun uint8 rcpi; 3262*4882a593Smuzhiyun uint8 rsni; 3263*4882a593Smuzhiyun struct ether_addr bssid; 3264*4882a593Smuzhiyun uint8 antenna_id; 3265*4882a593Smuzhiyun uint32 parent_tsf; 3266*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3267*4882a593Smuzhiyun typedef struct dot11_rmrep_bcn dot11_rmrep_bcn_t; 3268*4882a593Smuzhiyun #define DOT11_RMREP_BCN_LEN 26 3269*4882a593Smuzhiyun 3270*4882a593Smuzhiyun /* Beacon request measurement mode */ 3271*4882a593Smuzhiyun #define DOT11_RMREQ_BCN_PASSIVE 0 3272*4882a593Smuzhiyun #define DOT11_RMREQ_BCN_ACTIVE 1 3273*4882a593Smuzhiyun #define DOT11_RMREQ_BCN_TABLE 2 3274*4882a593Smuzhiyun 3275*4882a593Smuzhiyun /* Sub-element IDs for Beacon Request */ 3276*4882a593Smuzhiyun #define DOT11_RMREQ_BCN_SSID_ID 0 3277*4882a593Smuzhiyun #define DOT11_RMREQ_BCN_REPINFO_ID 1 3278*4882a593Smuzhiyun #define DOT11_RMREQ_BCN_REPDET_ID 2 3279*4882a593Smuzhiyun #define DOT11_RMREQ_BCN_REQUEST_ID 10 3280*4882a593Smuzhiyun #define DOT11_RMREQ_BCN_APCHREP_ID DOT11_MNG_AP_CHREP_ID 3281*4882a593Smuzhiyun #define DOT11_RMREQ_BCN_LAST_RPT_IND_REQ_ID 164 3282*4882a593Smuzhiyun 3283*4882a593Smuzhiyun /* Reporting Detail element definition */ 3284*4882a593Smuzhiyun #define DOT11_RMREQ_BCN_REPDET_FIXED 0 /* Fixed length fields only */ 3285*4882a593Smuzhiyun #define DOT11_RMREQ_BCN_REPDET_REQUEST 1 /* + requested information elems */ 3286*4882a593Smuzhiyun #define DOT11_RMREQ_BCN_REPDET_ALL 2 /* All fields */ 3287*4882a593Smuzhiyun 3288*4882a593Smuzhiyun /* Reporting Information (reporting condition) element definition */ 3289*4882a593Smuzhiyun #define DOT11_RMREQ_BCN_REPINFO_LEN 2 /* Beacon Reporting Information length */ 3290*4882a593Smuzhiyun #define DOT11_RMREQ_BCN_REPCOND_DEFAULT 0 /* Report to be issued after each measurement */ 3291*4882a593Smuzhiyun 3292*4882a593Smuzhiyun /* Last Beacon Report Indication Request definition */ 3293*4882a593Smuzhiyun #define DOT11_RMREQ_BCN_LAST_RPT_IND_REQ_ENAB 1 3294*4882a593Smuzhiyun 3295*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmrep_last_bcn_rpt_ind_req { 3296*4882a593Smuzhiyun uint8 id; /* DOT11_RMREQ_BCN_LAST_RPT_IND_REQ_ID */ 3297*4882a593Smuzhiyun uint8 len; /* length of remaining fields */ 3298*4882a593Smuzhiyun uint8 data; /* data = 1 means last bcn rpt ind requested */ 3299*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3300*4882a593Smuzhiyun typedef struct dot11_rmrep_last_bcn_rpt_ind_req dot11_rmrep_last_bcn_rpt_ind_req_t; 3301*4882a593Smuzhiyun 3302*4882a593Smuzhiyun /* Sub-element IDs for Beacon Report */ 3303*4882a593Smuzhiyun #define DOT11_RMREP_BCN_FRM_BODY 1 3304*4882a593Smuzhiyun #define DOT11_RMREP_BCN_FRM_BODY_FRAG_ID 2 3305*4882a593Smuzhiyun #define DOT11_RMREP_BCN_LAST_RPT_IND 164 3306*4882a593Smuzhiyun #define DOT11_RMREP_BCN_FRM_BODY_LEN_MAX 224 /* 802.11k-2008 7.3.2.22.6 */ 3307*4882a593Smuzhiyun 3308*4882a593Smuzhiyun /* Refer IEEE P802.11-REVmd/D1.0 9.4.2.21.7 Beacon report */ 3309*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmrep_bcn_frm_body_fragmt_id { 3310*4882a593Smuzhiyun uint8 id; /* DOT11_RMREP_BCN_FRM_BODY_FRAG_ID */ 3311*4882a593Smuzhiyun uint8 len; /* length of remaining fields */ 3312*4882a593Smuzhiyun /* More fragments(B15), fragment Id(B8-B14), Bcn rpt instance ID (B0 - B7) */ 3313*4882a593Smuzhiyun uint16 frag_info_rpt_id; 3314*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3315*4882a593Smuzhiyun 3316*4882a593Smuzhiyun typedef struct dot11_rmrep_bcn_frm_body_fragmt_id dot11_rmrep_bcn_frm_body_fragmt_id_t; 3317*4882a593Smuzhiyun 3318*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmrep_bcn_frm_body_frag_id { 3319*4882a593Smuzhiyun uint8 id; /* DOT11_RMREP_BCN_FRM_BODY_FRAG_ID */ 3320*4882a593Smuzhiyun uint8 len; /* length of remaining fields */ 3321*4882a593Smuzhiyun uint8 bcn_rpt_id; /* Bcn rpt instance ID */ 3322*4882a593Smuzhiyun uint8 frag_info; /* fragment Id(7 bits) | More fragments(1 bit) */ 3323*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3324*4882a593Smuzhiyun 3325*4882a593Smuzhiyun typedef struct dot11_rmrep_bcn_frm_body_frag_id dot11_rmrep_bcn_frm_body_frag_id_t; 3326*4882a593Smuzhiyun #define DOT11_RMREP_BCNRPT_FRAG_ID_DATA_LEN 2u 3327*4882a593Smuzhiyun #define DOT11_RMREP_BCNRPT_FRAG_ID_SE_LEN sizeof(dot11_rmrep_bcn_frm_body_frag_id_t) 3328*4882a593Smuzhiyun #define DOT11_RMREP_BCNRPT_FRAG_ID_NUM_SHIFT 1u 3329*4882a593Smuzhiyun #define DOT11_RMREP_BCNRPT_FRAGMT_ID_SE_LEN sizeof(dot11_rmrep_bcn_frm_body_fragmt_id_t) 3330*4882a593Smuzhiyun #define DOT11_RMREP_BCNRPT_BCN_RPT_ID_MASK 0x00FFu 3331*4882a593Smuzhiyun #define DOT11_RMREP_BCNRPT_FRAGMT_ID_NUM_SHIFT 8u 3332*4882a593Smuzhiyun #define DOT11_RMREP_BCNRPT_FRAGMT_ID_NUM_MASK 0x7F00u 3333*4882a593Smuzhiyun #define DOT11_RMREP_BCNRPT_MORE_FRAG_SHIFT 15u 3334*4882a593Smuzhiyun #define DOT11_RMREP_BCNRPT_MORE_FRAG_MASK 0x8000u 3335*4882a593Smuzhiyun 3336*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmrep_last_bcn_rpt_ind { 3337*4882a593Smuzhiyun uint8 id; /* DOT11_RMREP_BCN_LAST_RPT_IND */ 3338*4882a593Smuzhiyun uint8 len; /* length of remaining fields */ 3339*4882a593Smuzhiyun uint8 data; /* data = 1 is last bcn rpt */ 3340*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3341*4882a593Smuzhiyun 3342*4882a593Smuzhiyun typedef struct dot11_rmrep_last_bcn_rpt_ind dot11_rmrep_last_bcn_rpt_ind_t; 3343*4882a593Smuzhiyun #define DOT11_RMREP_LAST_BCN_RPT_IND_DATA_LEN 1 3344*4882a593Smuzhiyun #define DOT11_RMREP_LAST_BCN_RPT_IND_SE_LEN sizeof(dot11_rmrep_last_bcn_rpt_ind_t) 3345*4882a593Smuzhiyun 3346*4882a593Smuzhiyun /* Sub-element IDs for Frame Report */ 3347*4882a593Smuzhiyun #define DOT11_RMREP_FRAME_COUNT_REPORT 1 3348*4882a593Smuzhiyun 3349*4882a593Smuzhiyun /* Channel load request */ 3350*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmreq_chanload { 3351*4882a593Smuzhiyun uint8 id; /* use dot11_rm_ie_t ? */ 3352*4882a593Smuzhiyun uint8 len; 3353*4882a593Smuzhiyun uint8 token; 3354*4882a593Smuzhiyun uint8 mode; 3355*4882a593Smuzhiyun uint8 type; 3356*4882a593Smuzhiyun uint8 reg; 3357*4882a593Smuzhiyun uint8 channel; 3358*4882a593Smuzhiyun uint16 interval; 3359*4882a593Smuzhiyun uint16 duration; 3360*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3361*4882a593Smuzhiyun typedef struct dot11_rmreq_chanload dot11_rmreq_chanload_t; 3362*4882a593Smuzhiyun #define DOT11_RMREQ_CHANLOAD_LEN 11 3363*4882a593Smuzhiyun 3364*4882a593Smuzhiyun /** Channel load report */ 3365*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmrep_chanload { 3366*4882a593Smuzhiyun uint8 reg; 3367*4882a593Smuzhiyun uint8 channel; 3368*4882a593Smuzhiyun uint32 starttime[2]; 3369*4882a593Smuzhiyun uint16 duration; 3370*4882a593Smuzhiyun uint8 channel_load; 3371*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3372*4882a593Smuzhiyun typedef struct dot11_rmrep_chanload dot11_rmrep_chanload_t; 3373*4882a593Smuzhiyun #define DOT11_RMREP_CHANLOAD_LEN 13 3374*4882a593Smuzhiyun 3375*4882a593Smuzhiyun /** Noise histogram request */ 3376*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmreq_noise { 3377*4882a593Smuzhiyun uint8 id; /* use dot11_rm_ie_t ? */ 3378*4882a593Smuzhiyun uint8 len; 3379*4882a593Smuzhiyun uint8 token; 3380*4882a593Smuzhiyun uint8 mode; 3381*4882a593Smuzhiyun uint8 type; 3382*4882a593Smuzhiyun uint8 reg; 3383*4882a593Smuzhiyun uint8 channel; 3384*4882a593Smuzhiyun uint16 interval; 3385*4882a593Smuzhiyun uint16 duration; 3386*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3387*4882a593Smuzhiyun typedef struct dot11_rmreq_noise dot11_rmreq_noise_t; 3388*4882a593Smuzhiyun #define DOT11_RMREQ_NOISE_LEN 11 3389*4882a593Smuzhiyun 3390*4882a593Smuzhiyun /** Noise histogram report */ 3391*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmrep_noise { 3392*4882a593Smuzhiyun uint8 reg; 3393*4882a593Smuzhiyun uint8 channel; 3394*4882a593Smuzhiyun uint32 starttime[2]; 3395*4882a593Smuzhiyun uint16 duration; 3396*4882a593Smuzhiyun uint8 antid; 3397*4882a593Smuzhiyun uint8 anpi; 3398*4882a593Smuzhiyun uint8 ipi0_dens; 3399*4882a593Smuzhiyun uint8 ipi1_dens; 3400*4882a593Smuzhiyun uint8 ipi2_dens; 3401*4882a593Smuzhiyun uint8 ipi3_dens; 3402*4882a593Smuzhiyun uint8 ipi4_dens; 3403*4882a593Smuzhiyun uint8 ipi5_dens; 3404*4882a593Smuzhiyun uint8 ipi6_dens; 3405*4882a593Smuzhiyun uint8 ipi7_dens; 3406*4882a593Smuzhiyun uint8 ipi8_dens; 3407*4882a593Smuzhiyun uint8 ipi9_dens; 3408*4882a593Smuzhiyun uint8 ipi10_dens; 3409*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3410*4882a593Smuzhiyun typedef struct dot11_rmrep_noise dot11_rmrep_noise_t; 3411*4882a593Smuzhiyun #define DOT11_RMREP_NOISE_LEN 25 3412*4882a593Smuzhiyun 3413*4882a593Smuzhiyun /** Frame request */ 3414*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmreq_frame { 3415*4882a593Smuzhiyun uint8 id; /* use dot11_rm_ie_t ? */ 3416*4882a593Smuzhiyun uint8 len; 3417*4882a593Smuzhiyun uint8 token; 3418*4882a593Smuzhiyun uint8 mode; 3419*4882a593Smuzhiyun uint8 type; 3420*4882a593Smuzhiyun uint8 reg; 3421*4882a593Smuzhiyun uint8 channel; 3422*4882a593Smuzhiyun uint16 interval; 3423*4882a593Smuzhiyun uint16 duration; 3424*4882a593Smuzhiyun uint8 req_type; 3425*4882a593Smuzhiyun struct ether_addr ta; 3426*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3427*4882a593Smuzhiyun typedef struct dot11_rmreq_frame dot11_rmreq_frame_t; 3428*4882a593Smuzhiyun #define DOT11_RMREQ_FRAME_LEN 18 3429*4882a593Smuzhiyun 3430*4882a593Smuzhiyun /** Frame report */ 3431*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmrep_frame { 3432*4882a593Smuzhiyun uint8 reg; 3433*4882a593Smuzhiyun uint8 channel; 3434*4882a593Smuzhiyun uint32 starttime[2]; 3435*4882a593Smuzhiyun uint16 duration; 3436*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3437*4882a593Smuzhiyun typedef struct dot11_rmrep_frame dot11_rmrep_frame_t; 3438*4882a593Smuzhiyun #define DOT11_RMREP_FRAME_LEN 12 3439*4882a593Smuzhiyun 3440*4882a593Smuzhiyun /** Frame report entry */ 3441*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmrep_frmentry { 3442*4882a593Smuzhiyun struct ether_addr ta; 3443*4882a593Smuzhiyun struct ether_addr bssid; 3444*4882a593Smuzhiyun uint8 phy_type; 3445*4882a593Smuzhiyun uint8 avg_rcpi; 3446*4882a593Smuzhiyun uint8 last_rsni; 3447*4882a593Smuzhiyun uint8 last_rcpi; 3448*4882a593Smuzhiyun uint8 ant_id; 3449*4882a593Smuzhiyun uint16 frame_cnt; 3450*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3451*4882a593Smuzhiyun typedef struct dot11_rmrep_frmentry dot11_rmrep_frmentry_t; 3452*4882a593Smuzhiyun #define DOT11_RMREP_FRMENTRY_LEN 19 3453*4882a593Smuzhiyun 3454*4882a593Smuzhiyun /** STA statistics request */ 3455*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmreq_stat { 3456*4882a593Smuzhiyun uint8 id; /* use dot11_rm_ie_t ? */ 3457*4882a593Smuzhiyun uint8 len; 3458*4882a593Smuzhiyun uint8 token; 3459*4882a593Smuzhiyun uint8 mode; 3460*4882a593Smuzhiyun uint8 type; 3461*4882a593Smuzhiyun struct ether_addr peer; 3462*4882a593Smuzhiyun uint16 interval; 3463*4882a593Smuzhiyun uint16 duration; 3464*4882a593Smuzhiyun uint8 group_id; 3465*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3466*4882a593Smuzhiyun typedef struct dot11_rmreq_stat dot11_rmreq_stat_t; 3467*4882a593Smuzhiyun #define DOT11_RMREQ_STAT_LEN 16 3468*4882a593Smuzhiyun 3469*4882a593Smuzhiyun /** STA statistics report */ 3470*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmrep_stat { 3471*4882a593Smuzhiyun uint16 duration; 3472*4882a593Smuzhiyun uint8 group_id; 3473*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3474*4882a593Smuzhiyun typedef struct dot11_rmrep_stat dot11_rmrep_stat_t; 3475*4882a593Smuzhiyun 3476*4882a593Smuzhiyun /* Statistics Group Report: Group IDs */ 3477*4882a593Smuzhiyun enum { 3478*4882a593Smuzhiyun DOT11_RRM_STATS_GRP_ID_0 = 0, 3479*4882a593Smuzhiyun DOT11_RRM_STATS_GRP_ID_1, 3480*4882a593Smuzhiyun DOT11_RRM_STATS_GRP_ID_2, 3481*4882a593Smuzhiyun DOT11_RRM_STATS_GRP_ID_3, 3482*4882a593Smuzhiyun DOT11_RRM_STATS_GRP_ID_4, 3483*4882a593Smuzhiyun DOT11_RRM_STATS_GRP_ID_5, 3484*4882a593Smuzhiyun DOT11_RRM_STATS_GRP_ID_6, 3485*4882a593Smuzhiyun DOT11_RRM_STATS_GRP_ID_7, 3486*4882a593Smuzhiyun DOT11_RRM_STATS_GRP_ID_8, 3487*4882a593Smuzhiyun DOT11_RRM_STATS_GRP_ID_9, 3488*4882a593Smuzhiyun DOT11_RRM_STATS_GRP_ID_10, 3489*4882a593Smuzhiyun DOT11_RRM_STATS_GRP_ID_11, 3490*4882a593Smuzhiyun DOT11_RRM_STATS_GRP_ID_12, 3491*4882a593Smuzhiyun DOT11_RRM_STATS_GRP_ID_13, 3492*4882a593Smuzhiyun DOT11_RRM_STATS_GRP_ID_14, 3493*4882a593Smuzhiyun DOT11_RRM_STATS_GRP_ID_15, 3494*4882a593Smuzhiyun DOT11_RRM_STATS_GRP_ID_16 3495*4882a593Smuzhiyun }; 3496*4882a593Smuzhiyun 3497*4882a593Smuzhiyun /* Statistics Group Report: Group Data length */ 3498*4882a593Smuzhiyun #define DOT11_RRM_STATS_RPT_LEN_GRP_ID_0 28 3499*4882a593Smuzhiyun typedef struct rrm_stat_group_0 { 3500*4882a593Smuzhiyun uint32 txfrag; 3501*4882a593Smuzhiyun uint32 txmulti; 3502*4882a593Smuzhiyun uint32 txfail; 3503*4882a593Smuzhiyun uint32 rxframe; 3504*4882a593Smuzhiyun uint32 rxmulti; 3505*4882a593Smuzhiyun uint32 rxbadfcs; 3506*4882a593Smuzhiyun uint32 txframe; 3507*4882a593Smuzhiyun } rrm_stat_group_0_t; 3508*4882a593Smuzhiyun 3509*4882a593Smuzhiyun #define DOT11_RRM_STATS_RPT_LEN_GRP_ID_1 24 3510*4882a593Smuzhiyun typedef struct rrm_stat_group_1 { 3511*4882a593Smuzhiyun uint32 txretry; 3512*4882a593Smuzhiyun uint32 txretries; 3513*4882a593Smuzhiyun uint32 rxdup; 3514*4882a593Smuzhiyun uint32 txrts; 3515*4882a593Smuzhiyun uint32 rtsfail; 3516*4882a593Smuzhiyun uint32 ackfail; 3517*4882a593Smuzhiyun } rrm_stat_group_1_t; 3518*4882a593Smuzhiyun 3519*4882a593Smuzhiyun /* group 2-9 use same qos data structure (tid 0-7), total 52 bytes */ 3520*4882a593Smuzhiyun #define DOT11_RRM_STATS_RPT_LEN_GRP_ID_2_9 52 3521*4882a593Smuzhiyun typedef struct rrm_stat_group_qos { 3522*4882a593Smuzhiyun uint32 txfrag; 3523*4882a593Smuzhiyun uint32 txfail; 3524*4882a593Smuzhiyun uint32 txretry; 3525*4882a593Smuzhiyun uint32 txretries; 3526*4882a593Smuzhiyun uint32 rxdup; 3527*4882a593Smuzhiyun uint32 txrts; 3528*4882a593Smuzhiyun uint32 rtsfail; 3529*4882a593Smuzhiyun uint32 ackfail; 3530*4882a593Smuzhiyun uint32 rxfrag; 3531*4882a593Smuzhiyun uint32 txframe; 3532*4882a593Smuzhiyun uint32 txdrop; 3533*4882a593Smuzhiyun uint32 rxmpdu; 3534*4882a593Smuzhiyun uint32 rxretries; 3535*4882a593Smuzhiyun } rrm_stat_group_qos_t; 3536*4882a593Smuzhiyun 3537*4882a593Smuzhiyun /* dot11BSSAverageAccessDelay Group (only available at an AP): 8 byte */ 3538*4882a593Smuzhiyun #define DOT11_RRM_STATS_RPT_LEN_GRP_ID_10 8 3539*4882a593Smuzhiyun typedef BWL_PRE_PACKED_STRUCT struct rrm_stat_group_10 { 3540*4882a593Smuzhiyun uint8 apavgdelay; 3541*4882a593Smuzhiyun uint8 avgdelaybe; 3542*4882a593Smuzhiyun uint8 avgdelaybg; 3543*4882a593Smuzhiyun uint8 avgdelayvi; 3544*4882a593Smuzhiyun uint8 avgdelayvo; 3545*4882a593Smuzhiyun uint16 stacount; 3546*4882a593Smuzhiyun uint8 chanutil; 3547*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT rrm_stat_group_10_t; 3548*4882a593Smuzhiyun 3549*4882a593Smuzhiyun /* AMSDU, 40 bytes */ 3550*4882a593Smuzhiyun #define DOT11_RRM_STATS_RPT_LEN_GRP_ID_11 40 3551*4882a593Smuzhiyun typedef struct rrm_stat_group_11 { 3552*4882a593Smuzhiyun uint32 txamsdu; 3553*4882a593Smuzhiyun uint32 amsdufail; 3554*4882a593Smuzhiyun uint32 amsduretry; 3555*4882a593Smuzhiyun uint32 amsduretries; 3556*4882a593Smuzhiyun uint32 txamsdubyte_h; 3557*4882a593Smuzhiyun uint32 txamsdubyte_l; 3558*4882a593Smuzhiyun uint32 amsduackfail; 3559*4882a593Smuzhiyun uint32 rxamsdu; 3560*4882a593Smuzhiyun uint32 rxamsdubyte_h; 3561*4882a593Smuzhiyun uint32 rxamsdubyte_l; 3562*4882a593Smuzhiyun } rrm_stat_group_11_t; 3563*4882a593Smuzhiyun 3564*4882a593Smuzhiyun /* AMPDU, 36 bytes */ 3565*4882a593Smuzhiyun #define DOT11_RRM_STATS_RPT_LEN_GRP_ID_12 36 3566*4882a593Smuzhiyun typedef struct rrm_stat_group_12 { 3567*4882a593Smuzhiyun uint32 txampdu; 3568*4882a593Smuzhiyun uint32 txmpdu; 3569*4882a593Smuzhiyun uint32 txampdubyte_h; 3570*4882a593Smuzhiyun uint32 txampdubyte_l; 3571*4882a593Smuzhiyun uint32 rxampdu; 3572*4882a593Smuzhiyun uint32 rxmpdu; 3573*4882a593Smuzhiyun uint32 rxampdubyte_h; 3574*4882a593Smuzhiyun uint32 rxampdubyte_l; 3575*4882a593Smuzhiyun uint32 ampducrcfail; 3576*4882a593Smuzhiyun } rrm_stat_group_12_t; 3577*4882a593Smuzhiyun 3578*4882a593Smuzhiyun /* BACK etc, 36 bytes */ 3579*4882a593Smuzhiyun #define DOT11_RRM_STATS_RPT_LEN_GRP_ID_13 36 3580*4882a593Smuzhiyun typedef struct rrm_stat_group_13 { 3581*4882a593Smuzhiyun uint32 rximpbarfail; 3582*4882a593Smuzhiyun uint32 rxexpbarfail; 3583*4882a593Smuzhiyun uint32 chanwidthsw; 3584*4882a593Smuzhiyun uint32 txframe20mhz; 3585*4882a593Smuzhiyun uint32 txframe40mhz; 3586*4882a593Smuzhiyun uint32 rxframe20mhz; 3587*4882a593Smuzhiyun uint32 rxframe40mhz; 3588*4882a593Smuzhiyun uint32 psmpgrantdur; 3589*4882a593Smuzhiyun uint32 psmpuseddur; 3590*4882a593Smuzhiyun } rrm_stat_group_13_t; 3591*4882a593Smuzhiyun 3592*4882a593Smuzhiyun /* RD Dual CTS etc, 36 bytes */ 3593*4882a593Smuzhiyun #define DOT11_RRM_STATS_RPT_LEN_GRP_ID_14 36 3594*4882a593Smuzhiyun typedef struct rrm_stat_group_14 { 3595*4882a593Smuzhiyun uint32 grantrdgused; 3596*4882a593Smuzhiyun uint32 grantrdgunused; 3597*4882a593Smuzhiyun uint32 txframeingrantrdg; 3598*4882a593Smuzhiyun uint32 txbyteingrantrdg_h; 3599*4882a593Smuzhiyun uint32 txbyteingrantrdg_l; 3600*4882a593Smuzhiyun uint32 dualcts; 3601*4882a593Smuzhiyun uint32 dualctsfail; 3602*4882a593Smuzhiyun uint32 rtslsi; 3603*4882a593Smuzhiyun uint32 rtslsifail; 3604*4882a593Smuzhiyun } rrm_stat_group_14_t; 3605*4882a593Smuzhiyun 3606*4882a593Smuzhiyun /* bf and STBC etc, 20 bytes */ 3607*4882a593Smuzhiyun #define DOT11_RRM_STATS_RPT_LEN_GRP_ID_15 20 3608*4882a593Smuzhiyun typedef struct rrm_stat_group_15 { 3609*4882a593Smuzhiyun uint32 bfframe; 3610*4882a593Smuzhiyun uint32 stbccts; 3611*4882a593Smuzhiyun uint32 stbcctsfail; 3612*4882a593Smuzhiyun uint32 nonstbccts; 3613*4882a593Smuzhiyun uint32 nonstbcctsfail; 3614*4882a593Smuzhiyun } rrm_stat_group_15_t; 3615*4882a593Smuzhiyun 3616*4882a593Smuzhiyun /* RSNA, 28 bytes */ 3617*4882a593Smuzhiyun #define DOT11_RRM_STATS_RPT_LEN_GRP_ID_16 28 3618*4882a593Smuzhiyun typedef struct rrm_stat_group_16 { 3619*4882a593Smuzhiyun uint32 rsnacmacicverr; 3620*4882a593Smuzhiyun uint32 rsnacmacreplay; 3621*4882a593Smuzhiyun uint32 rsnarobustmgmtccmpreplay; 3622*4882a593Smuzhiyun uint32 rsnatkipicverr; 3623*4882a593Smuzhiyun uint32 rsnatkipicvreplay; 3624*4882a593Smuzhiyun uint32 rsnaccmpdecrypterr; 3625*4882a593Smuzhiyun uint32 rsnaccmpreplay; 3626*4882a593Smuzhiyun } rrm_stat_group_16_t; 3627*4882a593Smuzhiyun 3628*4882a593Smuzhiyun /* Transmit stream/category measurement request */ 3629*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmreq_tx_stream { 3630*4882a593Smuzhiyun uint8 id; /* use dot11_rm_ie_t ? */ 3631*4882a593Smuzhiyun uint8 len; 3632*4882a593Smuzhiyun uint8 token; 3633*4882a593Smuzhiyun uint8 mode; 3634*4882a593Smuzhiyun uint8 type; 3635*4882a593Smuzhiyun uint16 interval; 3636*4882a593Smuzhiyun uint16 duration; 3637*4882a593Smuzhiyun struct ether_addr peer; 3638*4882a593Smuzhiyun uint8 traffic_id; 3639*4882a593Smuzhiyun uint8 bin0_range; 3640*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3641*4882a593Smuzhiyun typedef struct dot11_rmreq_tx_stream dot11_rmreq_tx_stream_t; 3642*4882a593Smuzhiyun #define DOT11_RMREQ_TXSTREAM_LEN 17 3643*4882a593Smuzhiyun 3644*4882a593Smuzhiyun /** Transmit stream/category measurement report */ 3645*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmrep_tx_stream { 3646*4882a593Smuzhiyun uint32 starttime[2]; 3647*4882a593Smuzhiyun uint16 duration; 3648*4882a593Smuzhiyun struct ether_addr peer; 3649*4882a593Smuzhiyun uint8 traffic_id; 3650*4882a593Smuzhiyun uint8 reason; 3651*4882a593Smuzhiyun uint32 txmsdu_cnt; 3652*4882a593Smuzhiyun uint32 msdu_discarded_cnt; 3653*4882a593Smuzhiyun uint32 msdufailed_cnt; 3654*4882a593Smuzhiyun uint32 msduretry_cnt; 3655*4882a593Smuzhiyun uint32 cfpolls_lost_cnt; 3656*4882a593Smuzhiyun uint32 avrqueue_delay; 3657*4882a593Smuzhiyun uint32 avrtx_delay; 3658*4882a593Smuzhiyun uint8 bin0_range; 3659*4882a593Smuzhiyun uint32 bin0; 3660*4882a593Smuzhiyun uint32 bin1; 3661*4882a593Smuzhiyun uint32 bin2; 3662*4882a593Smuzhiyun uint32 bin3; 3663*4882a593Smuzhiyun uint32 bin4; 3664*4882a593Smuzhiyun uint32 bin5; 3665*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3666*4882a593Smuzhiyun typedef struct dot11_rmrep_tx_stream dot11_rmrep_tx_stream_t; 3667*4882a593Smuzhiyun #define DOT11_RMREP_TXSTREAM_LEN 71 3668*4882a593Smuzhiyun 3669*4882a593Smuzhiyun typedef struct rrm_tscm { 3670*4882a593Smuzhiyun uint32 msdu_tx; 3671*4882a593Smuzhiyun uint32 msdu_exp; 3672*4882a593Smuzhiyun uint32 msdu_fail; 3673*4882a593Smuzhiyun uint32 msdu_retries; 3674*4882a593Smuzhiyun uint32 cfpolls_lost; 3675*4882a593Smuzhiyun uint32 queue_delay; 3676*4882a593Smuzhiyun uint32 tx_delay_sum; 3677*4882a593Smuzhiyun uint32 tx_delay_cnt; 3678*4882a593Smuzhiyun uint32 bin0_range_us; 3679*4882a593Smuzhiyun uint32 bin0; 3680*4882a593Smuzhiyun uint32 bin1; 3681*4882a593Smuzhiyun uint32 bin2; 3682*4882a593Smuzhiyun uint32 bin3; 3683*4882a593Smuzhiyun uint32 bin4; 3684*4882a593Smuzhiyun uint32 bin5; 3685*4882a593Smuzhiyun } rrm_tscm_t; 3686*4882a593Smuzhiyun enum { 3687*4882a593Smuzhiyun DOT11_FTM_LOCATION_SUBJ_LOCAL = 0, /* Where am I? */ 3688*4882a593Smuzhiyun DOT11_FTM_LOCATION_SUBJ_REMOTE = 1, /* Where are you? */ 3689*4882a593Smuzhiyun DOT11_FTM_LOCATION_SUBJ_THIRDPARTY = 2 /* Where is he/she? */ 3690*4882a593Smuzhiyun }; 3691*4882a593Smuzhiyun 3692*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmreq_ftm_lci { 3693*4882a593Smuzhiyun uint8 id; 3694*4882a593Smuzhiyun uint8 len; 3695*4882a593Smuzhiyun uint8 token; 3696*4882a593Smuzhiyun uint8 mode; 3697*4882a593Smuzhiyun uint8 type; 3698*4882a593Smuzhiyun uint8 subj; 3699*4882a593Smuzhiyun 3700*4882a593Smuzhiyun /* Following 3 fields are unused. Keep for ROM compatibility. */ 3701*4882a593Smuzhiyun uint8 lat_res; 3702*4882a593Smuzhiyun uint8 lon_res; 3703*4882a593Smuzhiyun uint8 alt_res; 3704*4882a593Smuzhiyun 3705*4882a593Smuzhiyun /* optional sub-elements */ 3706*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3707*4882a593Smuzhiyun typedef struct dot11_rmreq_ftm_lci dot11_rmreq_ftm_lci_t; 3708*4882a593Smuzhiyun #define DOT11_RMREQ_LCI_LEN 9 3709*4882a593Smuzhiyun 3710*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmrep_ftm_lci { 3711*4882a593Smuzhiyun uint8 id; 3712*4882a593Smuzhiyun uint8 len; 3713*4882a593Smuzhiyun uint8 token; 3714*4882a593Smuzhiyun uint8 mode; 3715*4882a593Smuzhiyun uint8 type; 3716*4882a593Smuzhiyun uint8 lci_sub_id; 3717*4882a593Smuzhiyun uint8 lci_sub_len; 3718*4882a593Smuzhiyun /* optional LCI field */ 3719*4882a593Smuzhiyun /* optional sub-elements */ 3720*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3721*4882a593Smuzhiyun typedef struct dot11_rmrep_ftm_lci dot11_rmrep_ftm_lci_t; 3722*4882a593Smuzhiyun 3723*4882a593Smuzhiyun #define DOT11_FTM_LCI_SUBELEM_ID 0 3724*4882a593Smuzhiyun #define DOT11_FTM_LCI_SUBELEM_LEN 2 3725*4882a593Smuzhiyun #define DOT11_FTM_LCI_FIELD_LEN 16 3726*4882a593Smuzhiyun #define DOT11_FTM_LCI_UNKNOWN_LEN 2 3727*4882a593Smuzhiyun 3728*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmreq_ftm_civic { 3729*4882a593Smuzhiyun uint8 id; 3730*4882a593Smuzhiyun uint8 len; 3731*4882a593Smuzhiyun uint8 token; 3732*4882a593Smuzhiyun uint8 mode; 3733*4882a593Smuzhiyun uint8 type; 3734*4882a593Smuzhiyun uint8 subj; 3735*4882a593Smuzhiyun uint8 civloc_type; 3736*4882a593Smuzhiyun uint8 siu; /* service interval units */ 3737*4882a593Smuzhiyun uint16 si; /* service interval */ 3738*4882a593Smuzhiyun /* optional sub-elements */ 3739*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3740*4882a593Smuzhiyun typedef struct dot11_rmreq_ftm_civic dot11_rmreq_ftm_civic_t; 3741*4882a593Smuzhiyun #define DOT11_RMREQ_CIVIC_LEN 10 3742*4882a593Smuzhiyun 3743*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmrep_ftm_civic { 3744*4882a593Smuzhiyun uint8 id; 3745*4882a593Smuzhiyun uint8 len; 3746*4882a593Smuzhiyun uint8 token; 3747*4882a593Smuzhiyun uint8 mode; 3748*4882a593Smuzhiyun uint8 type; 3749*4882a593Smuzhiyun uint8 civloc_type; 3750*4882a593Smuzhiyun uint8 civloc_sub_id; 3751*4882a593Smuzhiyun uint8 civloc_sub_len; 3752*4882a593Smuzhiyun /* optional location civic field */ 3753*4882a593Smuzhiyun /* optional sub-elements */ 3754*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3755*4882a593Smuzhiyun typedef struct dot11_rmrep_ftm_civic dot11_rmrep_ftm_civic_t; 3756*4882a593Smuzhiyun 3757*4882a593Smuzhiyun #define DOT11_FTM_CIVIC_LOC_TYPE_RFC4776 0 3758*4882a593Smuzhiyun #define DOT11_FTM_CIVIC_SUBELEM_ID 0 3759*4882a593Smuzhiyun #define DOT11_FTM_CIVIC_SUBELEM_LEN 2 3760*4882a593Smuzhiyun #define DOT11_FTM_CIVIC_LOC_SI_NONE 0 3761*4882a593Smuzhiyun #define DOT11_FTM_CIVIC_TYPE_LEN 1 3762*4882a593Smuzhiyun #define DOT11_FTM_CIVIC_UNKNOWN_LEN 3 3763*4882a593Smuzhiyun 3764*4882a593Smuzhiyun /* Location Identifier measurement request */ 3765*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmreq_locid { 3766*4882a593Smuzhiyun uint8 id; 3767*4882a593Smuzhiyun uint8 len; 3768*4882a593Smuzhiyun uint8 token; 3769*4882a593Smuzhiyun uint8 mode; 3770*4882a593Smuzhiyun uint8 type; 3771*4882a593Smuzhiyun uint8 subj; 3772*4882a593Smuzhiyun uint8 siu; 3773*4882a593Smuzhiyun uint16 si; 3774*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3775*4882a593Smuzhiyun typedef struct dot11_rmreq_locid dot11_rmreq_locid_t; 3776*4882a593Smuzhiyun #define DOT11_RMREQ_LOCID_LEN 9 3777*4882a593Smuzhiyun 3778*4882a593Smuzhiyun /* Location Identifier measurement report */ 3779*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmrep_locid { 3780*4882a593Smuzhiyun uint8 id; 3781*4882a593Smuzhiyun uint8 len; 3782*4882a593Smuzhiyun uint8 token; 3783*4882a593Smuzhiyun uint8 mode; 3784*4882a593Smuzhiyun uint8 type; 3785*4882a593Smuzhiyun uint8 exp_tsf[8]; 3786*4882a593Smuzhiyun uint8 locid_sub_id; 3787*4882a593Smuzhiyun uint8 locid_sub_len; 3788*4882a593Smuzhiyun /* optional location identifier field */ 3789*4882a593Smuzhiyun /* optional sub-elements */ 3790*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3791*4882a593Smuzhiyun typedef struct dot11_rmrep_locid dot11_rmrep_locid_t; 3792*4882a593Smuzhiyun #define DOT11_LOCID_UNKNOWN_LEN 10 3793*4882a593Smuzhiyun #define DOT11_LOCID_SUBELEM_ID 0 3794*4882a593Smuzhiyun 3795*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ftm_range_subel { 3796*4882a593Smuzhiyun uint8 id; 3797*4882a593Smuzhiyun uint8 len; 3798*4882a593Smuzhiyun uint16 max_age; 3799*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3800*4882a593Smuzhiyun typedef struct dot11_ftm_range_subel dot11_ftm_range_subel_t; 3801*4882a593Smuzhiyun #define DOT11_FTM_RANGE_SUBELEM_ID 4 3802*4882a593Smuzhiyun #define DOT11_FTM_RANGE_SUBELEM_LEN 2 3803*4882a593Smuzhiyun 3804*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmreq_ftm_range { 3805*4882a593Smuzhiyun uint8 id; 3806*4882a593Smuzhiyun uint8 len; 3807*4882a593Smuzhiyun uint8 token; 3808*4882a593Smuzhiyun uint8 mode; 3809*4882a593Smuzhiyun uint8 type; 3810*4882a593Smuzhiyun uint16 max_init_delay; /* maximum random initial delay */ 3811*4882a593Smuzhiyun uint8 min_ap_count; 3812*4882a593Smuzhiyun uint8 data[1]; 3813*4882a593Smuzhiyun /* neighbor report sub-elements */ 3814*4882a593Smuzhiyun /* optional sub-elements */ 3815*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3816*4882a593Smuzhiyun typedef struct dot11_rmreq_ftm_range dot11_rmreq_ftm_range_t; 3817*4882a593Smuzhiyun #define DOT11_RMREQ_FTM_RANGE_LEN 8 3818*4882a593Smuzhiyun 3819*4882a593Smuzhiyun #define DOT11_FTM_RANGE_LEN 3 3820*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ftm_range_entry { 3821*4882a593Smuzhiyun uint32 start_tsf; /* 4 lsb of tsf */ 3822*4882a593Smuzhiyun struct ether_addr bssid; 3823*4882a593Smuzhiyun uint8 range[DOT11_FTM_RANGE_LEN]; 3824*4882a593Smuzhiyun uint8 max_err[DOT11_FTM_RANGE_LEN]; 3825*4882a593Smuzhiyun uint8 rsvd; 3826*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3827*4882a593Smuzhiyun typedef struct dot11_ftm_range_entry dot11_ftm_range_entry_t; 3828*4882a593Smuzhiyun #define DOT11_FTM_RANGE_ENTRY_MAX_COUNT 15 3829*4882a593Smuzhiyun 3830*4882a593Smuzhiyun enum { 3831*4882a593Smuzhiyun DOT11_FTM_RANGE_ERROR_AP_INCAPABLE = 2, 3832*4882a593Smuzhiyun DOT11_FTM_RANGE_ERROR_AP_FAILED = 3, 3833*4882a593Smuzhiyun DOT11_FTM_RANGE_ERROR_TX_FAILED = 8, 3834*4882a593Smuzhiyun DOT11_FTM_RANGE_ERROR_MAX 3835*4882a593Smuzhiyun }; 3836*4882a593Smuzhiyun 3837*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ftm_range_error_entry { 3838*4882a593Smuzhiyun uint32 start_tsf; /* 4 lsb of tsf */ 3839*4882a593Smuzhiyun struct ether_addr bssid; 3840*4882a593Smuzhiyun uint8 code; 3841*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3842*4882a593Smuzhiyun typedef struct dot11_ftm_range_error_entry dot11_ftm_range_error_entry_t; 3843*4882a593Smuzhiyun #define DOT11_FTM_RANGE_ERROR_ENTRY_MAX_COUNT 11 3844*4882a593Smuzhiyun 3845*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmrep_ftm_range { 3846*4882a593Smuzhiyun uint8 id; 3847*4882a593Smuzhiyun uint8 len; 3848*4882a593Smuzhiyun uint8 token; 3849*4882a593Smuzhiyun uint8 mode; 3850*4882a593Smuzhiyun uint8 type; 3851*4882a593Smuzhiyun uint8 entry_count; 3852*4882a593Smuzhiyun uint8 data[2]; /* includes pad */ 3853*4882a593Smuzhiyun /* 3854*4882a593Smuzhiyun dot11_ftm_range_entry_t entries[entry_count]; 3855*4882a593Smuzhiyun uint8 error_count; 3856*4882a593Smuzhiyun dot11_ftm_error_entry_t errors[error_count]; 3857*4882a593Smuzhiyun */ 3858*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3859*4882a593Smuzhiyun typedef struct dot11_rmrep_ftm_range dot11_rmrep_ftm_range_t; 3860*4882a593Smuzhiyun 3861*4882a593Smuzhiyun #define DOT11_FTM_RANGE_REP_MIN_LEN 6 /* No extra byte for error_count */ 3862*4882a593Smuzhiyun #define DOT11_FTM_RANGE_ENTRY_CNT_MAX 15 3863*4882a593Smuzhiyun #define DOT11_FTM_RANGE_ERROR_CNT_MAX 11 3864*4882a593Smuzhiyun #define DOT11_FTM_RANGE_REP_FIXED_LEN 1 /* No extra byte for error_count */ 3865*4882a593Smuzhiyun /** Measurement pause request */ 3866*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_rmreq_pause_time { 3867*4882a593Smuzhiyun uint8 id; /* use dot11_rm_ie_t ? */ 3868*4882a593Smuzhiyun uint8 len; 3869*4882a593Smuzhiyun uint8 token; 3870*4882a593Smuzhiyun uint8 mode; 3871*4882a593Smuzhiyun uint8 type; 3872*4882a593Smuzhiyun uint16 pause_time; 3873*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3874*4882a593Smuzhiyun typedef struct dot11_rmreq_pause_time dot11_rmreq_pause_time_t; 3875*4882a593Smuzhiyun #define DOT11_RMREQ_PAUSE_LEN 7 3876*4882a593Smuzhiyun 3877*4882a593Smuzhiyun /* Neighbor Report subelements ID (11k & 11v) */ 3878*4882a593Smuzhiyun #define DOT11_NGBR_TSF_INFO_SE_ID 1 3879*4882a593Smuzhiyun #define DOT11_NGBR_CCS_SE_ID 2 3880*4882a593Smuzhiyun #define DOT11_NGBR_BSSTRANS_PREF_SE_ID 3 3881*4882a593Smuzhiyun #define DOT11_NGBR_BSS_TERM_DUR_SE_ID 4 3882*4882a593Smuzhiyun #define DOT11_NGBR_BEARING_SE_ID 5 3883*4882a593Smuzhiyun #define DOT11_NGBR_WIDE_BW_CHAN_SE_ID 6 /* proposed */ 3884*4882a593Smuzhiyun 3885*4882a593Smuzhiyun /** Neighbor Report, BSS Transition Candidate Preference subelement */ 3886*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ngbr_bsstrans_pref_se { 3887*4882a593Smuzhiyun uint8 sub_id; 3888*4882a593Smuzhiyun uint8 len; 3889*4882a593Smuzhiyun uint8 preference; 3890*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3891*4882a593Smuzhiyun typedef struct dot11_ngbr_bsstrans_pref_se dot11_ngbr_bsstrans_pref_se_t; 3892*4882a593Smuzhiyun #define DOT11_NGBR_BSSTRANS_PREF_SE_LEN 1 3893*4882a593Smuzhiyun #define DOT11_NGBR_BSSTRANS_PREF_SE_IE_LEN 3 3894*4882a593Smuzhiyun #define DOT11_NGBR_BSSTRANS_PREF_SE_HIGHEST 0xff 3895*4882a593Smuzhiyun 3896*4882a593Smuzhiyun /** Neighbor Report, BSS Termination Duration subelement */ 3897*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ngbr_bss_term_dur_se { 3898*4882a593Smuzhiyun uint8 sub_id; 3899*4882a593Smuzhiyun uint8 len; 3900*4882a593Smuzhiyun uint8 tsf[8]; 3901*4882a593Smuzhiyun uint16 duration; 3902*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3903*4882a593Smuzhiyun typedef struct dot11_ngbr_bss_term_dur_se dot11_ngbr_bss_term_dur_se_t; 3904*4882a593Smuzhiyun #define DOT11_NGBR_BSS_TERM_DUR_SE_LEN 10 3905*4882a593Smuzhiyun 3906*4882a593Smuzhiyun /* Neighbor Report BSSID Information Field */ 3907*4882a593Smuzhiyun #define DOT11_NGBR_BI_REACHABILTY_UNKN 0x0002 3908*4882a593Smuzhiyun #define DOT11_NGBR_BI_REACHABILTY 0x0003 3909*4882a593Smuzhiyun #define DOT11_NGBR_BI_SEC 0x0004 3910*4882a593Smuzhiyun #define DOT11_NGBR_BI_KEY_SCOPE 0x0008 3911*4882a593Smuzhiyun #define DOT11_NGBR_BI_CAP 0x03f0 3912*4882a593Smuzhiyun #define DOT11_NGBR_BI_CAP_SPEC_MGMT 0x0010 3913*4882a593Smuzhiyun #define DOT11_NGBR_BI_CAP_QOS 0x0020 3914*4882a593Smuzhiyun #define DOT11_NGBR_BI_CAP_APSD 0x0040 3915*4882a593Smuzhiyun #define DOT11_NGBR_BI_CAP_RDIO_MSMT 0x0080 3916*4882a593Smuzhiyun #define DOT11_NGBR_BI_CAP_DEL_BA 0x0100 3917*4882a593Smuzhiyun #define DOT11_NGBR_BI_CAP_IMM_BA 0x0200 3918*4882a593Smuzhiyun #define DOT11_NGBR_BI_MOBILITY 0x0400 3919*4882a593Smuzhiyun #define DOT11_NGBR_BI_HT 0x0800 3920*4882a593Smuzhiyun #define DOT11_NGBR_BI_VHT 0x1000 3921*4882a593Smuzhiyun #define DOT11_NGBR_BI_FTM 0x2000 3922*4882a593Smuzhiyun 3923*4882a593Smuzhiyun /** Neighbor Report element (11k & 11v) */ 3924*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_neighbor_rep_ie { 3925*4882a593Smuzhiyun uint8 id; 3926*4882a593Smuzhiyun uint8 len; 3927*4882a593Smuzhiyun struct ether_addr bssid; 3928*4882a593Smuzhiyun uint32 bssid_info; 3929*4882a593Smuzhiyun uint8 reg; /* Operating class */ 3930*4882a593Smuzhiyun uint8 channel; 3931*4882a593Smuzhiyun uint8 phytype; 3932*4882a593Smuzhiyun uint8 data[1]; /* Variable size subelements */ 3933*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3934*4882a593Smuzhiyun typedef struct dot11_neighbor_rep_ie dot11_neighbor_rep_ie_t; 3935*4882a593Smuzhiyun #define DOT11_NEIGHBOR_REP_IE_FIXED_LEN 13u 3936*4882a593Smuzhiyun 3937*4882a593Smuzhiyun /* MLME Enumerations */ 3938*4882a593Smuzhiyun #define DOT11_BSSTYPE_INFRASTRUCTURE 0 /* d11 infrastructure */ 3939*4882a593Smuzhiyun #define DOT11_BSSTYPE_INDEPENDENT 1 /* d11 independent */ 3940*4882a593Smuzhiyun #define DOT11_BSSTYPE_ANY 2 /* d11 any BSS type */ 3941*4882a593Smuzhiyun #define DOT11_BSSTYPE_MESH 3 /* d11 Mesh */ 3942*4882a593Smuzhiyun #define DOT11_SCANTYPE_ACTIVE 0 /* d11 scan active */ 3943*4882a593Smuzhiyun #define DOT11_SCANTYPE_PASSIVE 1 /* d11 scan passive */ 3944*4882a593Smuzhiyun 3945*4882a593Smuzhiyun /** Link Measurement */ 3946*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_lmreq { 3947*4882a593Smuzhiyun uint8 category; /* category of action frame (5) */ 3948*4882a593Smuzhiyun uint8 action; /* radio measurement action */ 3949*4882a593Smuzhiyun uint8 token; /* dialog token */ 3950*4882a593Smuzhiyun uint8 txpwr; /* Transmit Power Used */ 3951*4882a593Smuzhiyun uint8 maxtxpwr; /* Max Transmit Power */ 3952*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3953*4882a593Smuzhiyun typedef struct dot11_lmreq dot11_lmreq_t; 3954*4882a593Smuzhiyun #define DOT11_LMREQ_LEN 5 3955*4882a593Smuzhiyun 3956*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_lmrep { 3957*4882a593Smuzhiyun uint8 category; /* category of action frame (5) */ 3958*4882a593Smuzhiyun uint8 action; /* radio measurement action */ 3959*4882a593Smuzhiyun uint8 token; /* dialog token */ 3960*4882a593Smuzhiyun dot11_tpc_rep_t tpc; /* TPC element */ 3961*4882a593Smuzhiyun uint8 rxant; /* Receive Antenna ID */ 3962*4882a593Smuzhiyun uint8 txant; /* Transmit Antenna ID */ 3963*4882a593Smuzhiyun uint8 rcpi; /* RCPI */ 3964*4882a593Smuzhiyun uint8 rsni; /* RSNI */ 3965*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3966*4882a593Smuzhiyun typedef struct dot11_lmrep dot11_lmrep_t; 3967*4882a593Smuzhiyun #define DOT11_LMREP_LEN 11 3968*4882a593Smuzhiyun 3969*4882a593Smuzhiyun #define DOT11_MP_CAP_SPECTRUM 0x01 /* d11 cap. spectrum */ 3970*4882a593Smuzhiyun #define DOT11_MP_CAP_SHORTSLOT 0x02 /* d11 cap. shortslot */ 3971*4882a593Smuzhiyun /* Measurement Pilot */ 3972*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_mprep { 3973*4882a593Smuzhiyun uint8 cap_info; /* Condensed capability Info. */ 3974*4882a593Smuzhiyun uint8 country[2]; /* Condensed country string */ 3975*4882a593Smuzhiyun uint8 opclass; /* Op. Class */ 3976*4882a593Smuzhiyun uint8 channel; /* Channel */ 3977*4882a593Smuzhiyun uint8 mp_interval; /* Measurement Pilot Interval */ 3978*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 3979*4882a593Smuzhiyun typedef struct dot11_mprep dot11_mprep_t; 3980*4882a593Smuzhiyun #define DOT11_MPREP_LEN 6 3981*4882a593Smuzhiyun 3982*4882a593Smuzhiyun /* 802.11 BRCM "Compromise" Pre N constants */ 3983*4882a593Smuzhiyun #define PREN_PREAMBLE 24 /* green field preamble time */ 3984*4882a593Smuzhiyun #define PREN_MM_EXT 12 /* extra mixed mode preamble time */ 3985*4882a593Smuzhiyun #define PREN_PREAMBLE_EXT 4 /* extra preamble (multiply by unique_streams-1) */ 3986*4882a593Smuzhiyun 3987*4882a593Smuzhiyun /* 802.11N PHY constants */ 3988*4882a593Smuzhiyun #define RIFS_11N_TIME 2 /* NPHY RIFS time */ 3989*4882a593Smuzhiyun 3990*4882a593Smuzhiyun /* 802.11 HT PLCP format 802.11n-2009, sec 20.3.9.4.3 3991*4882a593Smuzhiyun * HT-SIG is composed of two 24 bit parts, HT-SIG1 and HT-SIG2 3992*4882a593Smuzhiyun */ 3993*4882a593Smuzhiyun /* HT-SIG1 */ 3994*4882a593Smuzhiyun #define HT_SIG1_MCS_MASK 0x00007F 3995*4882a593Smuzhiyun #define HT_SIG1_CBW 0x000080 3996*4882a593Smuzhiyun #define HT_SIG1_HT_LENGTH 0xFFFF00 3997*4882a593Smuzhiyun 3998*4882a593Smuzhiyun /* HT-SIG2 */ 3999*4882a593Smuzhiyun #define HT_SIG2_SMOOTHING 0x000001 4000*4882a593Smuzhiyun #define HT_SIG2_NOT_SOUNDING 0x000002 4001*4882a593Smuzhiyun #define HT_SIG2_RESERVED 0x000004 4002*4882a593Smuzhiyun #define HT_SIG2_AGGREGATION 0x000008 4003*4882a593Smuzhiyun #define HT_SIG2_STBC_MASK 0x000030 4004*4882a593Smuzhiyun #define HT_SIG2_STBC_SHIFT 4 4005*4882a593Smuzhiyun #define HT_SIG2_FEC_CODING 0x000040 4006*4882a593Smuzhiyun #define HT_SIG2_SHORT_GI 0x000080 4007*4882a593Smuzhiyun #define HT_SIG2_ESS_MASK 0x000300 4008*4882a593Smuzhiyun #define HT_SIG2_ESS_SHIFT 8 4009*4882a593Smuzhiyun #define HT_SIG2_CRC 0x03FC00 4010*4882a593Smuzhiyun #define HT_SIG2_TAIL 0x1C0000 4011*4882a593Smuzhiyun 4012*4882a593Smuzhiyun /* HT Timing-related parameters (802.11-2012, sec 20.3.6) */ 4013*4882a593Smuzhiyun #define HT_T_LEG_PREAMBLE 16 4014*4882a593Smuzhiyun #define HT_T_L_SIG 4 4015*4882a593Smuzhiyun #define HT_T_SIG 8 4016*4882a593Smuzhiyun #define HT_T_LTF1 4 4017*4882a593Smuzhiyun #define HT_T_GF_LTF1 8 4018*4882a593Smuzhiyun #define HT_T_LTFs 4 4019*4882a593Smuzhiyun #define HT_T_STF 4 4020*4882a593Smuzhiyun #define HT_T_GF_STF 8 4021*4882a593Smuzhiyun #define HT_T_SYML 4 4022*4882a593Smuzhiyun 4023*4882a593Smuzhiyun #define HT_N_SERVICE 16 /* bits in SERVICE field */ 4024*4882a593Smuzhiyun #define HT_N_TAIL 6 /* tail bits per BCC encoder */ 4025*4882a593Smuzhiyun 4026*4882a593Smuzhiyun /* 802.11 A PHY constants */ 4027*4882a593Smuzhiyun #define APHY_SLOT_TIME 9 /* APHY slot time */ 4028*4882a593Smuzhiyun #define APHY_SIFS_TIME 16 /* APHY SIFS time */ 4029*4882a593Smuzhiyun #define APHY_DIFS_TIME (APHY_SIFS_TIME + (2 * APHY_SLOT_TIME)) /* APHY DIFS time */ 4030*4882a593Smuzhiyun #define APHY_PREAMBLE_TIME 16 /* APHY preamble time */ 4031*4882a593Smuzhiyun #define APHY_SIGNAL_TIME 4 /* APHY signal time */ 4032*4882a593Smuzhiyun #define APHY_SYMBOL_TIME 4 /* APHY symbol time */ 4033*4882a593Smuzhiyun #define APHY_SERVICE_NBITS 16 /* APHY service nbits */ 4034*4882a593Smuzhiyun #define APHY_TAIL_NBITS 6 /* APHY tail nbits */ 4035*4882a593Smuzhiyun #define APHY_CWMIN 15 /* APHY cwmin */ 4036*4882a593Smuzhiyun #define APHY_PHYHDR_DUR 20 /* APHY PHY Header Duration */ 4037*4882a593Smuzhiyun 4038*4882a593Smuzhiyun /* 802.11 B PHY constants */ 4039*4882a593Smuzhiyun #define BPHY_SLOT_TIME 20 /* BPHY slot time */ 4040*4882a593Smuzhiyun #define BPHY_SIFS_TIME 10 /* BPHY SIFS time */ 4041*4882a593Smuzhiyun #define BPHY_DIFS_TIME 50 /* BPHY DIFS time */ 4042*4882a593Smuzhiyun #define BPHY_PLCP_TIME 192 /* BPHY PLCP time */ 4043*4882a593Smuzhiyun #define BPHY_PLCP_SHORT_TIME 96 /* BPHY PLCP short time */ 4044*4882a593Smuzhiyun #define BPHY_CWMIN 31 /* BPHY cwmin */ 4045*4882a593Smuzhiyun #define BPHY_SHORT_PHYHDR_DUR 96 /* BPHY Short PHY Header Duration */ 4046*4882a593Smuzhiyun #define BPHY_LONG_PHYHDR_DUR 192 /* BPHY Long PHY Header Duration */ 4047*4882a593Smuzhiyun 4048*4882a593Smuzhiyun /* 802.11 G constants */ 4049*4882a593Smuzhiyun #define DOT11_OFDM_SIGNAL_EXTENSION 6 /* d11 OFDM signal extension */ 4050*4882a593Smuzhiyun 4051*4882a593Smuzhiyun #define PHY_CWMAX 1023 /* PHY cwmax */ 4052*4882a593Smuzhiyun 4053*4882a593Smuzhiyun #define DOT11_MAXNUMFRAGS 16 /* max # fragments per MSDU */ 4054*4882a593Smuzhiyun 4055*4882a593Smuzhiyun /* 802.11 VHT constants */ 4056*4882a593Smuzhiyun 4057*4882a593Smuzhiyun typedef int vht_group_id_t; 4058*4882a593Smuzhiyun 4059*4882a593Smuzhiyun /* for VHT-A1 */ 4060*4882a593Smuzhiyun /* SIG-A1 reserved bits */ 4061*4882a593Smuzhiyun #define VHT_SIGA1_CONST_MASK 0x800004 4062*4882a593Smuzhiyun 4063*4882a593Smuzhiyun #define VHT_SIGA1_BW_MASK 0x000003 4064*4882a593Smuzhiyun #define VHT_SIGA1_20MHZ_VAL 0x000000 4065*4882a593Smuzhiyun #define VHT_SIGA1_40MHZ_VAL 0x000001 4066*4882a593Smuzhiyun #define VHT_SIGA1_80MHZ_VAL 0x000002 4067*4882a593Smuzhiyun #define VHT_SIGA1_160MHZ_VAL 0x000003 4068*4882a593Smuzhiyun 4069*4882a593Smuzhiyun #define VHT_SIGA1_STBC 0x000008 4070*4882a593Smuzhiyun 4071*4882a593Smuzhiyun #define VHT_SIGA1_GID_MASK 0x0003f0 4072*4882a593Smuzhiyun #define VHT_SIGA1_GID_SHIFT 4 4073*4882a593Smuzhiyun #define VHT_SIGA1_GID_TO_AP 0x00 4074*4882a593Smuzhiyun #define VHT_SIGA1_GID_NOT_TO_AP 0x3f 4075*4882a593Smuzhiyun #define VHT_SIGA1_GID_MAX_GID 0x3f 4076*4882a593Smuzhiyun 4077*4882a593Smuzhiyun #define VHT_SIGA1_NSTS_SHIFT_MASK_USER0 0x001C00 4078*4882a593Smuzhiyun #define VHT_SIGA1_NSTS_SHIFT 10 4079*4882a593Smuzhiyun #define VHT_SIGA1_MAX_USERPOS 3 4080*4882a593Smuzhiyun 4081*4882a593Smuzhiyun #define VHT_SIGA1_PARTIAL_AID_MASK 0x3fe000 4082*4882a593Smuzhiyun #define VHT_SIGA1_PARTIAL_AID_SHIFT 13 4083*4882a593Smuzhiyun 4084*4882a593Smuzhiyun #define VHT_SIGA1_TXOP_PS_NOT_ALLOWED 0x400000 4085*4882a593Smuzhiyun 4086*4882a593Smuzhiyun /* for VHT-A2 */ 4087*4882a593Smuzhiyun #define VHT_SIGA2_GI_NONE 0x000000 4088*4882a593Smuzhiyun #define VHT_SIGA2_GI_SHORT 0x000001 4089*4882a593Smuzhiyun #define VHT_SIGA2_GI_W_MOD10 0x000002 4090*4882a593Smuzhiyun #define VHT_SIGA2_CODING_LDPC 0x000004 4091*4882a593Smuzhiyun #define VHT_SIGA2_LDPC_EXTRA_OFDM_SYM 0x000008 4092*4882a593Smuzhiyun #define VHT_SIGA2_BEAMFORM_ENABLE 0x000100 4093*4882a593Smuzhiyun #define VHT_SIGA2_MCS_SHIFT 4 4094*4882a593Smuzhiyun 4095*4882a593Smuzhiyun #define VHT_SIGA2_B9_RESERVED 0x000200 4096*4882a593Smuzhiyun #define VHT_SIGA2_TAIL_MASK 0xfc0000 4097*4882a593Smuzhiyun #define VHT_SIGA2_TAIL_VALUE 0x000000 4098*4882a593Smuzhiyun 4099*4882a593Smuzhiyun /* VHT Timing-related parameters (802.11ac D4.0, sec 22.3.6) */ 4100*4882a593Smuzhiyun #define VHT_T_LEG_PREAMBLE 16 4101*4882a593Smuzhiyun #define VHT_T_L_SIG 4 4102*4882a593Smuzhiyun #define VHT_T_SIG_A 8 4103*4882a593Smuzhiyun #define VHT_T_LTF 4 4104*4882a593Smuzhiyun #define VHT_T_STF 4 4105*4882a593Smuzhiyun #define VHT_T_SIG_B 4 4106*4882a593Smuzhiyun #define VHT_T_SYML 4 4107*4882a593Smuzhiyun 4108*4882a593Smuzhiyun #define VHT_N_SERVICE 16 /* bits in SERVICE field */ 4109*4882a593Smuzhiyun #define VHT_N_TAIL 6 /* tail bits per BCC encoder */ 4110*4882a593Smuzhiyun 4111*4882a593Smuzhiyun /** dot11Counters Table - 802.11 spec., Annex D */ 4112*4882a593Smuzhiyun typedef struct d11cnt { 4113*4882a593Smuzhiyun uint32 txfrag; /* dot11TransmittedFragmentCount */ 4114*4882a593Smuzhiyun uint32 txmulti; /* dot11MulticastTransmittedFrameCount */ 4115*4882a593Smuzhiyun uint32 txfail; /* dot11FailedCount */ 4116*4882a593Smuzhiyun uint32 txretry; /* dot11RetryCount */ 4117*4882a593Smuzhiyun uint32 txretrie; /* dot11MultipleRetryCount */ 4118*4882a593Smuzhiyun uint32 rxdup; /* dot11FrameduplicateCount */ 4119*4882a593Smuzhiyun uint32 txrts; /* dot11RTSSuccessCount */ 4120*4882a593Smuzhiyun uint32 txnocts; /* dot11RTSFailureCount */ 4121*4882a593Smuzhiyun uint32 txnoack; /* dot11ACKFailureCount */ 4122*4882a593Smuzhiyun uint32 rxfrag; /* dot11ReceivedFragmentCount */ 4123*4882a593Smuzhiyun uint32 rxmulti; /* dot11MulticastReceivedFrameCount */ 4124*4882a593Smuzhiyun uint32 rxcrc; /* dot11FCSErrorCount */ 4125*4882a593Smuzhiyun uint32 txfrmsnt; /* dot11TransmittedFrameCount */ 4126*4882a593Smuzhiyun uint32 rxundec; /* dot11WEPUndecryptableCount */ 4127*4882a593Smuzhiyun } d11cnt_t; 4128*4882a593Smuzhiyun 4129*4882a593Smuzhiyun /* OUI for BRCM proprietary IE */ 4130*4882a593Smuzhiyun #define BRCM_PROP_OUI "\x00\x90\x4C" /* Broadcom proprietary OUI */ 4131*4882a593Smuzhiyun 4132*4882a593Smuzhiyun /* Broadcom Proprietary OUI type list. Please update below page when adding a new type. 4133*4882a593Smuzhiyun * Twiki http://hwnbu-twiki.sj.broadcom.com/bin/view/Mwgroup/WlBrcmPropIE 4134*4882a593Smuzhiyun */ 4135*4882a593Smuzhiyun /* The following BRCM_PROP_OUI types are currently in use (defined in 4136*4882a593Smuzhiyun * relevant subsections). Each of them will be in a separate proprietary(221) IE 4137*4882a593Smuzhiyun * #define RWL_WIFI_DEFAULT 0 4138*4882a593Smuzhiyun * #define SES_VNDR_IE_TYPE 1 (defined in src/ses/shared/ses.h) 4139*4882a593Smuzhiyun * #define VHT_FEATURES_IE_TYPE 4 4140*4882a593Smuzhiyun * #define RWL_WIFI_FIND_MY_PEER 9 4141*4882a593Smuzhiyun * #define RWL_WIFI_FOUND_PEER 10 4142*4882a593Smuzhiyun * #define PROXD_IE_TYPE 11 4143*4882a593Smuzhiyun */ 4144*4882a593Smuzhiyun 4145*4882a593Smuzhiyun #define BRCM_FTM_IE_TYPE 14 4146*4882a593Smuzhiyun 4147*4882a593Smuzhiyun /* #define HT_CAP_IE_TYPE 51 4148*4882a593Smuzhiyun * #define HT_ADD_IE_TYPE 52 4149*4882a593Smuzhiyun * #define BRCM_EXTCH_IE_TYPE 53 4150*4882a593Smuzhiyun * #define MEMBER_OF_BRCM_PROP_IE_TYPE 54 4151*4882a593Smuzhiyun * #define BRCM_RELMACST_IE_TYPE 55 4152*4882a593Smuzhiyun * #define BRCM_EVT_WL_BSS_INFO 64 4153*4882a593Smuzhiyun * #define RWL_ACTION_WIFI_FRAG_TYPE 85 4154*4882a593Smuzhiyun * #define BTC_INFO_BRCM_PROP_IE_TYPE 90 4155*4882a593Smuzhiyun * #define ULB_BRCM_PROP_IE_TYPE 91 4156*4882a593Smuzhiyun * #define SDB_BRCM_PROP_IE_TYPE 92 4157*4882a593Smuzhiyun */ 4158*4882a593Smuzhiyun 4159*4882a593Smuzhiyun /* Action frame type for RWL */ 4160*4882a593Smuzhiyun #define RWL_WIFI_DEFAULT 0 4161*4882a593Smuzhiyun #define RWL_WIFI_FIND_MY_PEER 9 /* Used while finding server */ 4162*4882a593Smuzhiyun #define RWL_WIFI_FOUND_PEER 10 /* Server response to the client */ 4163*4882a593Smuzhiyun #define RWL_ACTION_WIFI_FRAG_TYPE 85 /* Fragment indicator for receiver */ 4164*4882a593Smuzhiyun 4165*4882a593Smuzhiyun #define PROXD_AF_TYPE 11 /* Wifi proximity action frame type */ 4166*4882a593Smuzhiyun #define BRCM_RELMACST_AF_TYPE 12 /* RMC action frame type */ 4167*4882a593Smuzhiyun 4168*4882a593Smuzhiyun /* Action frame type for FTM Initiator Report */ 4169*4882a593Smuzhiyun #define BRCM_FTM_VS_AF_TYPE 14 4170*4882a593Smuzhiyun enum { 4171*4882a593Smuzhiyun BRCM_FTM_VS_INITIATOR_RPT_SUBTYPE = 1, /* FTM Initiator Report */ 4172*4882a593Smuzhiyun BRCM_FTM_VS_COLLECT_SUBTYPE = 2, /* FTM Collect debug protocol */ 4173*4882a593Smuzhiyun }; 4174*4882a593Smuzhiyun 4175*4882a593Smuzhiyun /* Action frame type for vendor specific action frames */ 4176*4882a593Smuzhiyun #define VS_AF_TYPE 221 4177*4882a593Smuzhiyun 4178*4882a593Smuzhiyun #ifdef WL_VS_AFTX 4179*4882a593Smuzhiyun /* Vendor specific action frame subtype for transmit using SU EDCA */ 4180*4882a593Smuzhiyun #define VS_AF_SUBTYPE_SUEDCA 1 4181*4882a593Smuzhiyun 4182*4882a593Smuzhiyun #define VENDOR_PROP_OUI "\x00\x17\xF2" 4183*4882a593Smuzhiyun #endif /* WL_VS_AFTX */ 4184*4882a593Smuzhiyun 4185*4882a593Smuzhiyun /* 4186*4882a593Smuzhiyun * This BRCM_PROP_OUI types is intended for use in events to embed additional 4187*4882a593Smuzhiyun * data, and would not be expected to appear on the air -- but having an IE 4188*4882a593Smuzhiyun * format allows IE frame data with extra data in events in that allows for 4189*4882a593Smuzhiyun * more flexible parsing. 4190*4882a593Smuzhiyun */ 4191*4882a593Smuzhiyun #define BRCM_EVT_WL_BSS_INFO 64 4192*4882a593Smuzhiyun 4193*4882a593Smuzhiyun /** 4194*4882a593Smuzhiyun * Following is the generic structure for brcm_prop_ie (uses BRCM_PROP_OUI). 4195*4882a593Smuzhiyun * DPT uses this format with type set to DPT_IE_TYPE 4196*4882a593Smuzhiyun */ 4197*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct brcm_prop_ie_s { 4198*4882a593Smuzhiyun uint8 id; /* IE ID, 221, DOT11_MNG_PROPR_ID */ 4199*4882a593Smuzhiyun uint8 len; /* IE length */ 4200*4882a593Smuzhiyun uint8 oui[3]; /* Proprietary OUI, BRCM_PROP_OUI */ 4201*4882a593Smuzhiyun uint8 type; /* type of this IE */ 4202*4882a593Smuzhiyun uint16 cap; /* DPT capabilities */ 4203*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 4204*4882a593Smuzhiyun typedef struct brcm_prop_ie_s brcm_prop_ie_t; 4205*4882a593Smuzhiyun 4206*4882a593Smuzhiyun #define BRCM_PROP_IE_LEN 6 /* len of fixed part of brcm_prop ie */ 4207*4882a593Smuzhiyun 4208*4882a593Smuzhiyun #define DPT_IE_TYPE 2 4209*4882a593Smuzhiyun 4210*4882a593Smuzhiyun #define BRCM_SYSCAP_IE_TYPE 3 4211*4882a593Smuzhiyun #define WET_TUNNEL_IE_TYPE 3 4212*4882a593Smuzhiyun 4213*4882a593Smuzhiyun /* brcm syscap_ie cap */ 4214*4882a593Smuzhiyun #define BRCM_SYSCAP_WET_TUNNEL 0x0100 /* Device with WET_TUNNEL support */ 4215*4882a593Smuzhiyun 4216*4882a593Smuzhiyun /* BRCM OUI: Used in the proprietary(221) IE in all broadcom devices */ 4217*4882a593Smuzhiyun #define BRCM_OUI "\x00\x10\x18" /* Broadcom OUI */ 4218*4882a593Smuzhiyun 4219*4882a593Smuzhiyun /** BRCM info element */ 4220*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct brcm_ie { 4221*4882a593Smuzhiyun uint8 id; /* IE ID, 221, DOT11_MNG_PROPR_ID */ 4222*4882a593Smuzhiyun uint8 len; /* IE length */ 4223*4882a593Smuzhiyun uint8 oui[3]; /* Proprietary OUI, BRCM_OUI */ 4224*4882a593Smuzhiyun uint8 ver; /* type/ver of this IE */ 4225*4882a593Smuzhiyun uint8 assoc; /* # of assoc STAs */ 4226*4882a593Smuzhiyun uint8 flags; /* misc flags */ 4227*4882a593Smuzhiyun uint8 flags1; /* misc flags */ 4228*4882a593Smuzhiyun uint16 amsdu_mtu_pref; /* preferred A-MSDU MTU */ 4229*4882a593Smuzhiyun uint8 flags2; /* Bit 0: DTPC TX cap, Bit 1: DTPC Recv Cap */ 4230*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 4231*4882a593Smuzhiyun typedef struct brcm_ie brcm_ie_t; 4232*4882a593Smuzhiyun #define BRCM_IE_LEN 12u /* BRCM IE length */ 4233*4882a593Smuzhiyun #define BRCM_IE_VER 2u /* BRCM IE version */ 4234*4882a593Smuzhiyun #define BRCM_IE_LEGACY_AES_VER 1u /* BRCM IE legacy AES version */ 4235*4882a593Smuzhiyun 4236*4882a593Smuzhiyun /* brcm_ie flags */ 4237*4882a593Smuzhiyun #define BRF_ABCAP 0x1 /* afterburner is obsolete, defined for backward compat */ 4238*4882a593Smuzhiyun #define BRF_ABRQRD 0x2 /* afterburner is obsolete, defined for backward compat */ 4239*4882a593Smuzhiyun #define BRF_LZWDS 0x4 /* lazy wds enabled */ 4240*4882a593Smuzhiyun #define BRF_BLOCKACK 0x8 /* BlockACK capable */ 4241*4882a593Smuzhiyun #define BRF_ABCOUNTER_MASK 0xf0 /* afterburner is obsolete, defined for backward compat */ 4242*4882a593Smuzhiyun #define BRF_PROP_11N_MCS 0x10 /* re-use afterburner bit */ 4243*4882a593Smuzhiyun #define BRF_MEDIA_CLIENT 0x20 /* re-use afterburner bit to indicate media client device */ 4244*4882a593Smuzhiyun 4245*4882a593Smuzhiyun /** 4246*4882a593Smuzhiyun * Support for Broadcom proprietary HT MCS rates. Re-uses afterburner bits since 4247*4882a593Smuzhiyun * afterburner is not used anymore. Checks for BRF_ABCAP to stay compliant with 'old' 4248*4882a593Smuzhiyun * images in the field. 4249*4882a593Smuzhiyun */ 4250*4882a593Smuzhiyun #define GET_BRF_PROP_11N_MCS(brcm_ie) \ 4251*4882a593Smuzhiyun (!((brcm_ie)->flags & BRF_ABCAP) && ((brcm_ie)->flags & BRF_PROP_11N_MCS)) 4252*4882a593Smuzhiyun 4253*4882a593Smuzhiyun /* brcm_ie flags1 */ 4254*4882a593Smuzhiyun #define BRF1_AMSDU 0x1 /* A-MSDU capable */ 4255*4882a593Smuzhiyun #define BRF1_WNM 0x2 /* WNM capable */ 4256*4882a593Smuzhiyun #define BRF1_WMEPS 0x4 /* AP is capable of handling WME + PS w/o APSD */ 4257*4882a593Smuzhiyun #define BRF1_PSOFIX 0x8 /* AP has fixed PS mode out-of-order packets */ 4258*4882a593Smuzhiyun #define BRF1_RX_LARGE_AGG 0x10 /* device can rx large aggregates */ 4259*4882a593Smuzhiyun #define BRF1_RFAWARE_DCS 0x20 /* RFAWARE dynamic channel selection (DCS) */ 4260*4882a593Smuzhiyun #define BRF1_SOFTAP 0x40 /* Configure as Broadcom SOFTAP */ 4261*4882a593Smuzhiyun #define BRF1_DWDS 0x80 /* DWDS capable */ 4262*4882a593Smuzhiyun 4263*4882a593Smuzhiyun /* brcm_ie flags2 */ 4264*4882a593Smuzhiyun #define BRF2_DTPC_TX 0x1u /* DTPC: DTPC TX Cap */ 4265*4882a593Smuzhiyun #define BRF2_DTPC_RX 0x2u /* DTPC: DTPC RX Cap */ 4266*4882a593Smuzhiyun #define BRF2_DTPC_TX_RX 0x3u /* DTPC: Enable Both DTPC TX and RX Cap */ 4267*4882a593Smuzhiyun 4268*4882a593Smuzhiyun /** Vendor IE structure */ 4269*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct vndr_ie { 4270*4882a593Smuzhiyun uchar id; 4271*4882a593Smuzhiyun uchar len; 4272*4882a593Smuzhiyun uchar oui [3]; 4273*4882a593Smuzhiyun uchar data [1]; /* Variable size data */ 4274*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 4275*4882a593Smuzhiyun typedef struct vndr_ie vndr_ie_t; 4276*4882a593Smuzhiyun 4277*4882a593Smuzhiyun #define VNDR_IE_HDR_LEN 2u /* id + len field */ 4278*4882a593Smuzhiyun #define VNDR_IE_MIN_LEN 3u /* size of the oui field */ 4279*4882a593Smuzhiyun #define VNDR_IE_FIXED_LEN (VNDR_IE_HDR_LEN + VNDR_IE_MIN_LEN) 4280*4882a593Smuzhiyun 4281*4882a593Smuzhiyun #define VNDR_IE_MAX_LEN 255u /* vendor IE max length, without ID and len */ 4282*4882a593Smuzhiyun 4283*4882a593Smuzhiyun /** BRCM PROP DEVICE PRIMARY MAC ADDRESS IE */ 4284*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct member_of_brcm_prop_ie { 4285*4882a593Smuzhiyun uchar id; 4286*4882a593Smuzhiyun uchar len; 4287*4882a593Smuzhiyun uchar oui[3]; 4288*4882a593Smuzhiyun uint8 type; /* type indicates what follows */ 4289*4882a593Smuzhiyun struct ether_addr ea; /* Device Primary MAC Adrress */ 4290*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 4291*4882a593Smuzhiyun typedef struct member_of_brcm_prop_ie member_of_brcm_prop_ie_t; 4292*4882a593Smuzhiyun 4293*4882a593Smuzhiyun #define MEMBER_OF_BRCM_PROP_IE_LEN 10 /* IE max length */ 4294*4882a593Smuzhiyun #define MEMBER_OF_BRCM_PROP_IE_HDRLEN (sizeof(member_of_brcm_prop_ie_t)) 4295*4882a593Smuzhiyun #define MEMBER_OF_BRCM_PROP_IE_TYPE 54 /* used in prop IE 221 only */ 4296*4882a593Smuzhiyun 4297*4882a593Smuzhiyun /** BRCM Reliable Multicast IE */ 4298*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct relmcast_brcm_prop_ie { 4299*4882a593Smuzhiyun uint8 id; 4300*4882a593Smuzhiyun uint8 len; 4301*4882a593Smuzhiyun uint8 oui[3]; 4302*4882a593Smuzhiyun uint8 type; /* type indicates what follows */ 4303*4882a593Smuzhiyun struct ether_addr ea; /* The ack sender's MAC Adrress */ 4304*4882a593Smuzhiyun struct ether_addr mcast_ea; /* The multicast MAC address */ 4305*4882a593Smuzhiyun uint8 updtmo; /* time interval(second) for client to send null packet to report its rssi */ 4306*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 4307*4882a593Smuzhiyun typedef struct relmcast_brcm_prop_ie relmcast_brcm_prop_ie_t; 4308*4882a593Smuzhiyun 4309*4882a593Smuzhiyun /* IE length */ 4310*4882a593Smuzhiyun /* BRCM_PROP_IE_LEN = sizeof(relmcast_brcm_prop_ie_t)-((sizeof (id) + sizeof (len)))? */ 4311*4882a593Smuzhiyun #define RELMCAST_BRCM_PROP_IE_LEN (sizeof(relmcast_brcm_prop_ie_t)-(2*sizeof(uint8))) 4312*4882a593Smuzhiyun 4313*4882a593Smuzhiyun #define RELMCAST_BRCM_PROP_IE_TYPE 55 /* used in prop IE 221 only */ 4314*4882a593Smuzhiyun 4315*4882a593Smuzhiyun /* BRCM BTC IE */ 4316*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct btc_brcm_prop_ie { 4317*4882a593Smuzhiyun uint8 id; 4318*4882a593Smuzhiyun uint8 len; 4319*4882a593Smuzhiyun uint8 oui[3]; 4320*4882a593Smuzhiyun uint8 type; /* type inidicates what follows */ 4321*4882a593Smuzhiyun uint32 info; 4322*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 4323*4882a593Smuzhiyun typedef struct btc_brcm_prop_ie btc_brcm_prop_ie_t; 4324*4882a593Smuzhiyun 4325*4882a593Smuzhiyun #define BTC_INFO_BRCM_PROP_IE_TYPE 90 4326*4882a593Smuzhiyun #define BRCM_BTC_INFO_TYPE_LEN (sizeof(btc_brcm_prop_ie_t) - (2 * sizeof(uint8))) 4327*4882a593Smuzhiyun 4328*4882a593Smuzhiyun /* ************* HT definitions. ************* */ 4329*4882a593Smuzhiyun #define MCSSET_LEN 16 /* 16-bits per 8-bit set to give 128-bits bitmap of MCS Index */ 4330*4882a593Smuzhiyun #define MAX_MCS_NUM (128) /* max mcs number = 128 */ 4331*4882a593Smuzhiyun #define BASIC_HT_MCS 0xFFu /* HT MCS supported rates */ 4332*4882a593Smuzhiyun 4333*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct ht_cap_ie { 4334*4882a593Smuzhiyun uint16 cap; 4335*4882a593Smuzhiyun uint8 params; 4336*4882a593Smuzhiyun uint8 supp_mcs[MCSSET_LEN]; 4337*4882a593Smuzhiyun uint16 ext_htcap; 4338*4882a593Smuzhiyun uint32 txbf_cap; 4339*4882a593Smuzhiyun uint8 as_cap; 4340*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 4341*4882a593Smuzhiyun typedef struct ht_cap_ie ht_cap_ie_t; 4342*4882a593Smuzhiyun 4343*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ht_cap_ie { 4344*4882a593Smuzhiyun uint8 id; 4345*4882a593Smuzhiyun uint8 len; 4346*4882a593Smuzhiyun ht_cap_ie_t ht_cap; 4347*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 4348*4882a593Smuzhiyun typedef struct dot11_ht_cap_ie dot11_ht_cap_ie_t; 4349*4882a593Smuzhiyun 4350*4882a593Smuzhiyun /* CAP IE: HT 1.0 spec. simply stole a 802.11 IE, we use our prop. IE until this is resolved */ 4351*4882a593Smuzhiyun /* the capability IE is primarily used to convey this nodes abilities */ 4352*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct ht_prop_cap_ie { 4353*4882a593Smuzhiyun uint8 id; /* IE ID, 221, DOT11_MNG_PROPR_ID */ 4354*4882a593Smuzhiyun uint8 len; /* IE length */ 4355*4882a593Smuzhiyun uint8 oui[3]; /* Proprietary OUI, BRCM_PROP_OUI */ 4356*4882a593Smuzhiyun uint8 type; /* type indicates what follows */ 4357*4882a593Smuzhiyun ht_cap_ie_t cap_ie; 4358*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 4359*4882a593Smuzhiyun typedef struct ht_prop_cap_ie ht_prop_cap_ie_t; 4360*4882a593Smuzhiyun 4361*4882a593Smuzhiyun #define HT_PROP_IE_OVERHEAD 4 /* overhead bytes for prop oui ie */ 4362*4882a593Smuzhiyun #define HT_CAP_IE_LEN 26 /* HT capability len (based on .11n d2.0) */ 4363*4882a593Smuzhiyun #define HT_CAP_IE_TYPE 51 /* used in prop IE 221 only */ 4364*4882a593Smuzhiyun 4365*4882a593Smuzhiyun #define HT_CAP_LDPC_CODING 0x0001 /* Support for rx of LDPC coded pkts */ 4366*4882a593Smuzhiyun #define HT_CAP_40MHZ 0x0002 /* FALSE:20Mhz, TRUE:20/40MHZ supported */ 4367*4882a593Smuzhiyun #define HT_CAP_MIMO_PS_MASK 0x000C /* Mimo PS mask */ 4368*4882a593Smuzhiyun #define HT_CAP_MIMO_PS_SHIFT 0x0002 /* Mimo PS shift */ 4369*4882a593Smuzhiyun #define HT_CAP_MIMO_PS_OFF 0x0003 /* Mimo PS, no restriction */ 4370*4882a593Smuzhiyun #define HT_CAP_MIMO_PS_RTS 0x0001 /* Mimo PS, send RTS/CTS around MIMO frames */ 4371*4882a593Smuzhiyun #define HT_CAP_MIMO_PS_ON 0x0000 /* Mimo PS, MIMO disallowed */ 4372*4882a593Smuzhiyun #define HT_CAP_GF 0x0010 /* Greenfield preamble support */ 4373*4882a593Smuzhiyun #define HT_CAP_SHORT_GI_20 0x0020 /* 20MHZ short guard interval support */ 4374*4882a593Smuzhiyun #define HT_CAP_SHORT_GI_40 0x0040 /* 40Mhz short guard interval support */ 4375*4882a593Smuzhiyun #define HT_CAP_TX_STBC 0x0080 /* Tx STBC support */ 4376*4882a593Smuzhiyun #define HT_CAP_RX_STBC_MASK 0x0300 /* Rx STBC mask */ 4377*4882a593Smuzhiyun #define HT_CAP_RX_STBC_SHIFT 8 /* Rx STBC shift */ 4378*4882a593Smuzhiyun #define HT_CAP_DELAYED_BA 0x0400 /* delayed BA support */ 4379*4882a593Smuzhiyun #define HT_CAP_MAX_AMSDU 0x0800 /* Max AMSDU size in bytes , 0=3839, 1=7935 */ 4380*4882a593Smuzhiyun 4381*4882a593Smuzhiyun #define HT_CAP_DSSS_CCK 0x1000 /* DSSS/CCK supported by the BSS */ 4382*4882a593Smuzhiyun #define HT_CAP_PSMP 0x2000 /* Power Save Multi Poll support */ 4383*4882a593Smuzhiyun #define HT_CAP_40MHZ_INTOLERANT 0x4000 /* 40MHz Intolerant */ 4384*4882a593Smuzhiyun #define HT_CAP_LSIG_TXOP 0x8000 /* L-SIG TXOP protection support */ 4385*4882a593Smuzhiyun 4386*4882a593Smuzhiyun #define HT_CAP_RX_STBC_NO 0x0 /* no rx STBC support */ 4387*4882a593Smuzhiyun #define HT_CAP_RX_STBC_ONE_STREAM 0x1 /* rx STBC support of 1 spatial stream */ 4388*4882a593Smuzhiyun #define HT_CAP_RX_STBC_TWO_STREAM 0x2 /* rx STBC support of 1-2 spatial streams */ 4389*4882a593Smuzhiyun #define HT_CAP_RX_STBC_THREE_STREAM 0x3 /* rx STBC support of 1-3 spatial streams */ 4390*4882a593Smuzhiyun 4391*4882a593Smuzhiyun #define HT_CAP_TXBF_CAP_IMPLICIT_TXBF_RX 0x1 4392*4882a593Smuzhiyun #define HT_CAP_TXBF_CAP_NDP_RX 0x8 4393*4882a593Smuzhiyun #define HT_CAP_TXBF_CAP_NDP_TX 0x10 4394*4882a593Smuzhiyun #define HT_CAP_TXBF_CAP_EXPLICIT_CSI 0x100 4395*4882a593Smuzhiyun #define HT_CAP_TXBF_CAP_EXPLICIT_NC_STEERING 0x200 4396*4882a593Smuzhiyun #define HT_CAP_TXBF_CAP_EXPLICIT_C_STEERING 0x400 4397*4882a593Smuzhiyun #define HT_CAP_TXBF_CAP_EXPLICIT_CSI_FB_MASK 0x1800 4398*4882a593Smuzhiyun #define HT_CAP_TXBF_CAP_EXPLICIT_CSI_FB_SHIFT 11 4399*4882a593Smuzhiyun #define HT_CAP_TXBF_CAP_EXPLICIT_NC_FB_MASK 0x6000 4400*4882a593Smuzhiyun #define HT_CAP_TXBF_CAP_EXPLICIT_NC_FB_SHIFT 13 4401*4882a593Smuzhiyun #define HT_CAP_TXBF_CAP_EXPLICIT_C_FB_MASK 0x18000 4402*4882a593Smuzhiyun #define HT_CAP_TXBF_CAP_EXPLICIT_C_FB_SHIFT 15 4403*4882a593Smuzhiyun #define HT_CAP_TXBF_CAP_CSI_BFR_ANT_SHIFT 19 4404*4882a593Smuzhiyun #define HT_CAP_TXBF_CAP_NC_BFR_ANT_SHIFT 21 4405*4882a593Smuzhiyun #define HT_CAP_TXBF_CAP_C_BFR_ANT_SHIFT 23 4406*4882a593Smuzhiyun #define HT_CAP_TXBF_CAP_C_BFR_ANT_MASK 0x1800000 4407*4882a593Smuzhiyun 4408*4882a593Smuzhiyun #define HT_CAP_TXBF_CAP_CHAN_ESTIM_SHIFT 27 4409*4882a593Smuzhiyun #define HT_CAP_TXBF_CAP_CHAN_ESTIM_MASK 0x18000000 4410*4882a593Smuzhiyun 4411*4882a593Smuzhiyun #define HT_CAP_TXBF_FB_TYPE_NONE 0 4412*4882a593Smuzhiyun #define HT_CAP_TXBF_FB_TYPE_DELAYED 1 4413*4882a593Smuzhiyun #define HT_CAP_TXBF_FB_TYPE_IMMEDIATE 2 4414*4882a593Smuzhiyun #define HT_CAP_TXBF_FB_TYPE_BOTH 3 4415*4882a593Smuzhiyun 4416*4882a593Smuzhiyun #define HT_CAP_TX_BF_CAP_EXPLICIT_CSI_FB_MASK 0x400 4417*4882a593Smuzhiyun #define HT_CAP_TX_BF_CAP_EXPLICIT_CSI_FB_SHIFT 10 4418*4882a593Smuzhiyun #define HT_CAP_TX_BF_CAP_EXPLICIT_COMPRESSED_FB_MASK 0x18000 4419*4882a593Smuzhiyun #define HT_CAP_TX_BF_CAP_EXPLICIT_COMPRESSED_FB_SHIFT 15 4420*4882a593Smuzhiyun 4421*4882a593Smuzhiyun #define HT_CAP_MCS_FLAGS_SUPP_BYTE 12 /* byte offset in HT Cap Supported MCS for various flags */ 4422*4882a593Smuzhiyun #define HT_CAP_MCS_RX_8TO15_BYTE_OFFSET 1 4423*4882a593Smuzhiyun #define HT_CAP_MCS_FLAGS_TX_RX_UNEQUAL 0x02 4424*4882a593Smuzhiyun #define HT_CAP_MCS_FLAGS_MAX_SPATIAL_STREAM_MASK 0x0C 4425*4882a593Smuzhiyun 4426*4882a593Smuzhiyun #define VHT_MAX_MPDU 11454 /* max mpdu size for now (bytes) */ 4427*4882a593Smuzhiyun #define VHT_MPDU_MSDU_DELTA 56 /* Difference in spec - vht mpdu, amsdu len */ 4428*4882a593Smuzhiyun /* Max AMSDU len - per spec */ 4429*4882a593Smuzhiyun #define VHT_MAX_AMSDU (VHT_MAX_MPDU - VHT_MPDU_MSDU_DELTA) 4430*4882a593Smuzhiyun 4431*4882a593Smuzhiyun #define HT_MAX_AMSDU 7935 /* max amsdu size (bytes) per the HT spec */ 4432*4882a593Smuzhiyun #define HT_MIN_AMSDU 3835 /* min amsdu size (bytes) per the HT spec */ 4433*4882a593Smuzhiyun 4434*4882a593Smuzhiyun #define HT_PARAMS_RX_FACTOR_MASK 0x03 /* ampdu rcv factor mask */ 4435*4882a593Smuzhiyun #define HT_PARAMS_DENSITY_MASK 0x1C /* ampdu density mask */ 4436*4882a593Smuzhiyun #define HT_PARAMS_DENSITY_SHIFT 2 /* ampdu density shift */ 4437*4882a593Smuzhiyun 4438*4882a593Smuzhiyun /* HT/AMPDU specific define */ 4439*4882a593Smuzhiyun #define AMPDU_MAX_MPDU_DENSITY 7 /* max mpdu density; in 1/4 usec units */ 4440*4882a593Smuzhiyun #define AMPDU_DENSITY_NONE 0 /* No density requirement */ 4441*4882a593Smuzhiyun #define AMPDU_DENSITY_1over4_US 1 /* 1/4 us density */ 4442*4882a593Smuzhiyun #define AMPDU_DENSITY_1over2_US 2 /* 1/2 us density */ 4443*4882a593Smuzhiyun #define AMPDU_DENSITY_1_US 3 /* 1 us density */ 4444*4882a593Smuzhiyun #define AMPDU_DENSITY_2_US 4 /* 2 us density */ 4445*4882a593Smuzhiyun #define AMPDU_DENSITY_4_US 5 /* 4 us density */ 4446*4882a593Smuzhiyun #define AMPDU_DENSITY_8_US 6 /* 8 us density */ 4447*4882a593Smuzhiyun #define AMPDU_DENSITY_16_US 7 /* 16 us density */ 4448*4882a593Smuzhiyun #define AMPDU_RX_FACTOR_8K 0 /* max rcv ampdu len (8kb) */ 4449*4882a593Smuzhiyun #define AMPDU_RX_FACTOR_16K 1 /* max rcv ampdu len (16kb) */ 4450*4882a593Smuzhiyun #define AMPDU_RX_FACTOR_32K 2 /* max rcv ampdu len (32kb) */ 4451*4882a593Smuzhiyun #define AMPDU_RX_FACTOR_64K 3 /* max rcv ampdu len (64kb) */ 4452*4882a593Smuzhiyun 4453*4882a593Smuzhiyun /* AMPDU RX factors for VHT rates */ 4454*4882a593Smuzhiyun #define AMPDU_RX_FACTOR_128K 4 /* max rcv ampdu len (128kb) */ 4455*4882a593Smuzhiyun #define AMPDU_RX_FACTOR_256K 5 /* max rcv ampdu len (256kb) */ 4456*4882a593Smuzhiyun #define AMPDU_RX_FACTOR_512K 6 /* max rcv ampdu len (512kb) */ 4457*4882a593Smuzhiyun #define AMPDU_RX_FACTOR_1024K 7 /* max rcv ampdu len (1024kb) */ 4458*4882a593Smuzhiyun 4459*4882a593Smuzhiyun #define AMPDU_RX_FACTOR_BASE 8*1024 /* ampdu factor base for rx len */ 4460*4882a593Smuzhiyun #define AMPDU_RX_FACTOR_BASE_PWR 13 /* ampdu factor base for rx len in power of 2 */ 4461*4882a593Smuzhiyun 4462*4882a593Smuzhiyun #define AMPDU_DELIMITER_LEN 4u /* length of ampdu delimiter */ 4463*4882a593Smuzhiyun #define AMPDU_DELIMITER_LEN_MAX 63 /* max length of ampdu delimiter(enforced in HW) */ 4464*4882a593Smuzhiyun 4465*4882a593Smuzhiyun #define HT_CAP_EXT_PCO 0x0001 4466*4882a593Smuzhiyun #define HT_CAP_EXT_PCO_TTIME_MASK 0x0006 4467*4882a593Smuzhiyun #define HT_CAP_EXT_PCO_TTIME_SHIFT 1 4468*4882a593Smuzhiyun #define HT_CAP_EXT_MCS_FEEDBACK_MASK 0x0300 4469*4882a593Smuzhiyun #define HT_CAP_EXT_MCS_FEEDBACK_SHIFT 8 4470*4882a593Smuzhiyun #define HT_CAP_EXT_HTC 0x0400 4471*4882a593Smuzhiyun #define HT_CAP_EXT_RD_RESP 0x0800 4472*4882a593Smuzhiyun 4473*4882a593Smuzhiyun /** 'ht_add' is called 'HT Operation' information element in the 802.11 standard */ 4474*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct ht_add_ie { 4475*4882a593Smuzhiyun uint8 ctl_ch; /* control channel number */ 4476*4882a593Smuzhiyun uint8 byte1; /* ext ch,rec. ch. width, RIFS support */ 4477*4882a593Smuzhiyun uint16 opmode; /* operation mode */ 4478*4882a593Smuzhiyun uint16 misc_bits; /* misc bits */ 4479*4882a593Smuzhiyun uint8 basic_mcs[MCSSET_LEN]; /* required MCS set */ 4480*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 4481*4882a593Smuzhiyun typedef struct ht_add_ie ht_add_ie_t; 4482*4882a593Smuzhiyun 4483*4882a593Smuzhiyun /* ADD IE: HT 1.0 spec. simply stole a 802.11 IE, we use our prop. IE until this is resolved */ 4484*4882a593Smuzhiyun /* the additional IE is primarily used to convey the current BSS configuration */ 4485*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct ht_prop_add_ie { 4486*4882a593Smuzhiyun uint8 id; /* IE ID, 221, DOT11_MNG_PROPR_ID */ 4487*4882a593Smuzhiyun uint8 len; /* IE length */ 4488*4882a593Smuzhiyun uint8 oui[3]; /* Proprietary OUI, BRCM_PROP_OUI */ 4489*4882a593Smuzhiyun uint8 type; /* indicates what follows */ 4490*4882a593Smuzhiyun ht_add_ie_t add_ie; 4491*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 4492*4882a593Smuzhiyun typedef struct ht_prop_add_ie ht_prop_add_ie_t; 4493*4882a593Smuzhiyun 4494*4882a593Smuzhiyun #define HT_ADD_IE_LEN 22 /* HT capability len (based on .11n d1.0) */ 4495*4882a593Smuzhiyun #define HT_ADD_IE_TYPE 52 /* faked out as current spec is illegal */ 4496*4882a593Smuzhiyun 4497*4882a593Smuzhiyun /* byte1 defn's */ 4498*4882a593Smuzhiyun #define HT_BW_ANY 0x04 /* set, STA can use 20 or 40MHz */ 4499*4882a593Smuzhiyun #define HT_RIFS_PERMITTED 0x08 /* RIFS allowed */ 4500*4882a593Smuzhiyun 4501*4882a593Smuzhiyun /* opmode defn's */ 4502*4882a593Smuzhiyun #define HT_OPMODE_MASK 0x0003 /* protection mode mask */ 4503*4882a593Smuzhiyun #define HT_OPMODE_SHIFT 0 /* protection mode shift */ 4504*4882a593Smuzhiyun #define HT_OPMODE_PURE 0x0000 /* protection mode PURE */ 4505*4882a593Smuzhiyun #define HT_OPMODE_OPTIONAL 0x0001 /* protection mode optional */ 4506*4882a593Smuzhiyun #define HT_OPMODE_HT20IN40 0x0002 /* protection mode 20MHz HT in 40MHz BSS */ 4507*4882a593Smuzhiyun #define HT_OPMODE_MIXED 0x0003 /* protection mode Mixed Mode */ 4508*4882a593Smuzhiyun #define HT_OPMODE_NONGF 0x0004 /* protection mode non-GF */ 4509*4882a593Smuzhiyun #define DOT11N_TXBURST 0x0008 /* Tx burst limit */ 4510*4882a593Smuzhiyun #define DOT11N_OBSS_NONHT 0x0010 /* OBSS Non-HT STA present */ 4511*4882a593Smuzhiyun #define HT_OPMODE_CCFS2_MASK 0x1fe0 /* Channel Center Frequency Segment 2 mask */ 4512*4882a593Smuzhiyun #define HT_OPMODE_CCFS2_SHIFT 5 /* Channel Center Frequency Segment 2 shift */ 4513*4882a593Smuzhiyun 4514*4882a593Smuzhiyun /* misc_bites defn's */ 4515*4882a593Smuzhiyun #define HT_BASIC_STBC_MCS 0x007f /* basic STBC MCS */ 4516*4882a593Smuzhiyun #define HT_DUAL_STBC_PROT 0x0080 /* Dual STBC Protection */ 4517*4882a593Smuzhiyun #define HT_SECOND_BCN 0x0100 /* Secondary beacon support */ 4518*4882a593Smuzhiyun #define HT_LSIG_TXOP 0x0200 /* L-SIG TXOP Protection full support */ 4519*4882a593Smuzhiyun #define HT_PCO_ACTIVE 0x0400 /* PCO active */ 4520*4882a593Smuzhiyun #define HT_PCO_PHASE 0x0800 /* PCO phase */ 4521*4882a593Smuzhiyun #define HT_DUALCTS_PROTECTION 0x0080 /* DUAL CTS protection needed */ 4522*4882a593Smuzhiyun 4523*4882a593Smuzhiyun /* Tx Burst Limits */ 4524*4882a593Smuzhiyun #define DOT11N_2G_TXBURST_LIMIT 6160 /* 2G band Tx burst limit per 802.11n Draft 1.10 (usec) */ 4525*4882a593Smuzhiyun #define DOT11N_5G_TXBURST_LIMIT 3080 /* 5G band Tx burst limit per 802.11n Draft 1.10 (usec) */ 4526*4882a593Smuzhiyun 4527*4882a593Smuzhiyun /* Macros for opmode */ 4528*4882a593Smuzhiyun #define GET_HT_OPMODE(add_ie) ((ltoh16_ua(&add_ie->opmode) & HT_OPMODE_MASK) \ 4529*4882a593Smuzhiyun >> HT_OPMODE_SHIFT) 4530*4882a593Smuzhiyun #define HT_MIXEDMODE_PRESENT(add_ie) ((ltoh16_ua(&add_ie->opmode) & HT_OPMODE_MASK) \ 4531*4882a593Smuzhiyun == HT_OPMODE_MIXED) /* mixed mode present */ 4532*4882a593Smuzhiyun #define HT_HT20_PRESENT(add_ie) ((ltoh16_ua(&add_ie->opmode) & HT_OPMODE_MASK) \ 4533*4882a593Smuzhiyun == HT_OPMODE_HT20IN40) /* 20MHz HT present */ 4534*4882a593Smuzhiyun #define HT_OPTIONAL_PRESENT(add_ie) ((ltoh16_ua(&add_ie->opmode) & HT_OPMODE_MASK) \ 4535*4882a593Smuzhiyun == HT_OPMODE_OPTIONAL) /* Optional protection present */ 4536*4882a593Smuzhiyun #define HT_USE_PROTECTION(add_ie) (HT_HT20_PRESENT((add_ie)) || \ 4537*4882a593Smuzhiyun HT_MIXEDMODE_PRESENT((add_ie))) /* use protection */ 4538*4882a593Smuzhiyun #define HT_NONGF_PRESENT(add_ie) ((ltoh16_ua(&add_ie->opmode) & HT_OPMODE_NONGF) \ 4539*4882a593Smuzhiyun == HT_OPMODE_NONGF) /* non-GF present */ 4540*4882a593Smuzhiyun #define DOT11N_TXBURST_PRESENT(add_ie) ((ltoh16_ua(&add_ie->opmode) & DOT11N_TXBURST) \ 4541*4882a593Smuzhiyun == DOT11N_TXBURST) /* Tx Burst present */ 4542*4882a593Smuzhiyun #define DOT11N_OBSS_NONHT_PRESENT(add_ie) ((ltoh16_ua(&add_ie->opmode) & DOT11N_OBSS_NONHT) \ 4543*4882a593Smuzhiyun == DOT11N_OBSS_NONHT) /* OBSS Non-HT present */ 4544*4882a593Smuzhiyun #define HT_OPMODE_CCFS2_GET(add_ie) ((ltoh16_ua(&(add_ie)->opmode) & HT_OPMODE_CCFS2_MASK) \ 4545*4882a593Smuzhiyun >> HT_OPMODE_CCFS2_SHIFT) /* get CCFS2 */ 4546*4882a593Smuzhiyun #define HT_OPMODE_CCFS2_SET(add_ie, ccfs2) do { /* set CCFS2 */ \ 4547*4882a593Smuzhiyun (add_ie)->opmode &= htol16(~HT_OPMODE_CCFS2_MASK); \ 4548*4882a593Smuzhiyun (add_ie)->opmode |= htol16(((ccfs2) << HT_OPMODE_CCFS2_SHIFT) & HT_OPMODE_CCFS2_MASK); \ 4549*4882a593Smuzhiyun } while (0) 4550*4882a593Smuzhiyun 4551*4882a593Smuzhiyun /* Macros for HT MCS field access */ 4552*4882a593Smuzhiyun #define HT_CAP_MCS_BITMASK(supp_mcs) \ 4553*4882a593Smuzhiyun ((supp_mcs)[HT_CAP_MCS_RX_8TO15_BYTE_OFFSET]) 4554*4882a593Smuzhiyun #define HT_CAP_MCS_TX_RX_UNEQUAL(supp_mcs) \ 4555*4882a593Smuzhiyun ((supp_mcs)[HT_CAP_MCS_FLAGS_SUPP_BYTE] & HT_CAP_MCS_FLAGS_TX_RX_UNEQUAL) 4556*4882a593Smuzhiyun #define HT_CAP_MCS_TX_STREAM_SUPPORT(supp_mcs) \ 4557*4882a593Smuzhiyun ((supp_mcs)[HT_CAP_MCS_FLAGS_SUPP_BYTE] & HT_CAP_MCS_FLAGS_MAX_SPATIAL_STREAM_MASK) 4558*4882a593Smuzhiyun 4559*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct obss_params { 4560*4882a593Smuzhiyun uint16 passive_dwell; 4561*4882a593Smuzhiyun uint16 active_dwell; 4562*4882a593Smuzhiyun uint16 bss_widthscan_interval; 4563*4882a593Smuzhiyun uint16 passive_total; 4564*4882a593Smuzhiyun uint16 active_total; 4565*4882a593Smuzhiyun uint16 chanwidth_transition_dly; 4566*4882a593Smuzhiyun uint16 activity_threshold; 4567*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 4568*4882a593Smuzhiyun typedef struct obss_params obss_params_t; 4569*4882a593Smuzhiyun 4570*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_obss_ie { 4571*4882a593Smuzhiyun uint8 id; 4572*4882a593Smuzhiyun uint8 len; 4573*4882a593Smuzhiyun obss_params_t obss_params; 4574*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 4575*4882a593Smuzhiyun typedef struct dot11_obss_ie dot11_obss_ie_t; 4576*4882a593Smuzhiyun #define DOT11_OBSS_SCAN_IE_LEN sizeof(obss_params_t) /* HT OBSS len (based on 802.11n d3.0) */ 4577*4882a593Smuzhiyun 4578*4882a593Smuzhiyun /* HT control field */ 4579*4882a593Smuzhiyun #define HT_CTRL_LA_TRQ 0x00000002 /* sounding request */ 4580*4882a593Smuzhiyun #define HT_CTRL_LA_MAI 0x0000003C /* MCS request or antenna selection indication */ 4581*4882a593Smuzhiyun #define HT_CTRL_LA_MAI_SHIFT 2 4582*4882a593Smuzhiyun #define HT_CTRL_LA_MAI_MRQ 0x00000004 /* MCS request */ 4583*4882a593Smuzhiyun #define HT_CTRL_LA_MAI_MSI 0x00000038 /* MCS request sequence identifier */ 4584*4882a593Smuzhiyun #define HT_CTRL_LA_MFSI 0x000001C0 /* MFB sequence identifier */ 4585*4882a593Smuzhiyun #define HT_CTRL_LA_MFSI_SHIFT 6 4586*4882a593Smuzhiyun #define HT_CTRL_LA_MFB_ASELC 0x0000FE00 /* MCS feedback, antenna selection command/data */ 4587*4882a593Smuzhiyun #define HT_CTRL_LA_MFB_ASELC_SH 9 4588*4882a593Smuzhiyun #define HT_CTRL_LA_ASELC_CMD 0x00000C00 /* ASEL command */ 4589*4882a593Smuzhiyun #define HT_CTRL_LA_ASELC_DATA 0x0000F000 /* ASEL data */ 4590*4882a593Smuzhiyun #define HT_CTRL_CAL_POS 0x00030000 /* Calibration position */ 4591*4882a593Smuzhiyun #define HT_CTRL_CAL_SEQ 0x000C0000 /* Calibration sequence */ 4592*4882a593Smuzhiyun #define HT_CTRL_CSI_STEERING 0x00C00000 /* CSI/Steering */ 4593*4882a593Smuzhiyun #define HT_CTRL_CSI_STEER_SHIFT 22 4594*4882a593Smuzhiyun #define HT_CTRL_CSI_STEER_NFB 0 /* no fedback required */ 4595*4882a593Smuzhiyun #define HT_CTRL_CSI_STEER_CSI 1 /* CSI, H matrix */ 4596*4882a593Smuzhiyun #define HT_CTRL_CSI_STEER_NCOM 2 /* non-compressed beamforming */ 4597*4882a593Smuzhiyun #define HT_CTRL_CSI_STEER_COM 3 /* compressed beamforming */ 4598*4882a593Smuzhiyun #define HT_CTRL_NDP_ANNOUNCE 0x01000000 /* NDP announcement */ 4599*4882a593Smuzhiyun #define HT_CTRL_AC_CONSTRAINT 0x40000000 /* AC Constraint */ 4600*4882a593Smuzhiyun #define HT_CTRL_RDG_MOREPPDU 0x80000000 /* RDG/More PPDU */ 4601*4882a593Smuzhiyun 4602*4882a593Smuzhiyun /* ************* VHT definitions. ************* */ 4603*4882a593Smuzhiyun 4604*4882a593Smuzhiyun /** 4605*4882a593Smuzhiyun * VHT Capabilites IE (sec 8.4.2.160) 4606*4882a593Smuzhiyun */ 4607*4882a593Smuzhiyun 4608*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct vht_cap_ie { 4609*4882a593Smuzhiyun uint32 vht_cap_info; 4610*4882a593Smuzhiyun /* supported MCS set - 64 bit field */ 4611*4882a593Smuzhiyun uint16 rx_mcs_map; 4612*4882a593Smuzhiyun uint16 rx_max_rate; 4613*4882a593Smuzhiyun uint16 tx_mcs_map; 4614*4882a593Smuzhiyun uint16 tx_max_rate; 4615*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 4616*4882a593Smuzhiyun typedef struct vht_cap_ie vht_cap_ie_t; 4617*4882a593Smuzhiyun 4618*4882a593Smuzhiyun /* 4B cap_info + 8B supp_mcs */ 4619*4882a593Smuzhiyun #define VHT_CAP_IE_LEN 12 4620*4882a593Smuzhiyun 4621*4882a593Smuzhiyun /* VHT Capabilities Info field - 32bit - in VHT Cap IE */ 4622*4882a593Smuzhiyun #define VHT_CAP_INFO_MAX_MPDU_LEN_MASK 0x00000003 4623*4882a593Smuzhiyun #define VHT_CAP_INFO_SUPP_CHAN_WIDTH_MASK 0x0000000c 4624*4882a593Smuzhiyun #define VHT_CAP_INFO_LDPC 0x00000010 4625*4882a593Smuzhiyun #define VHT_CAP_INFO_SGI_80MHZ 0x00000020 4626*4882a593Smuzhiyun #define VHT_CAP_INFO_SGI_160MHZ 0x00000040 4627*4882a593Smuzhiyun #define VHT_CAP_INFO_TX_STBC 0x00000080 4628*4882a593Smuzhiyun #define VHT_CAP_INFO_RX_STBC_MASK 0x00000700 4629*4882a593Smuzhiyun #define VHT_CAP_INFO_RX_STBC_SHIFT 8u 4630*4882a593Smuzhiyun #define VHT_CAP_INFO_SU_BEAMFMR 0x00000800 4631*4882a593Smuzhiyun #define VHT_CAP_INFO_SU_BEAMFMEE 0x00001000 4632*4882a593Smuzhiyun #define VHT_CAP_INFO_NUM_BMFMR_ANT_MASK 0x0000e000 4633*4882a593Smuzhiyun #define VHT_CAP_INFO_NUM_BMFMR_ANT_SHIFT 13u 4634*4882a593Smuzhiyun #define VHT_CAP_INFO_NUM_SOUNDING_DIM_MASK 0x00070000 4635*4882a593Smuzhiyun #define VHT_CAP_INFO_NUM_SOUNDING_DIM_SHIFT 16u 4636*4882a593Smuzhiyun #define VHT_CAP_INFO_MU_BEAMFMR 0x00080000 4637*4882a593Smuzhiyun #define VHT_CAP_INFO_MU_BEAMFMEE 0x00100000 4638*4882a593Smuzhiyun #define VHT_CAP_INFO_TXOPPS 0x00200000 4639*4882a593Smuzhiyun #define VHT_CAP_INFO_HTCVHT 0x00400000 4640*4882a593Smuzhiyun #define VHT_CAP_INFO_AMPDU_MAXLEN_EXP_MASK 0x03800000 4641*4882a593Smuzhiyun #define VHT_CAP_INFO_AMPDU_MAXLEN_EXP_SHIFT 23u 4642*4882a593Smuzhiyun #define VHT_CAP_INFO_LINK_ADAPT_CAP_MASK 0x0c000000 4643*4882a593Smuzhiyun #define VHT_CAP_INFO_LINK_ADAPT_CAP_SHIFT 26u 4644*4882a593Smuzhiyun #define VHT_CAP_INFO_EXT_NSS_BW_SUP_MASK 0xc0000000 4645*4882a593Smuzhiyun #define VHT_CAP_INFO_EXT_NSS_BW_SUP_SHIFT 30u 4646*4882a593Smuzhiyun 4647*4882a593Smuzhiyun /* get Extended NSS BW Support passing vht cap info */ 4648*4882a593Smuzhiyun #define VHT_CAP_EXT_NSS_BW_SUP(cap_info) \ 4649*4882a593Smuzhiyun (((cap_info) & VHT_CAP_INFO_EXT_NSS_BW_SUP_MASK) >> VHT_CAP_INFO_EXT_NSS_BW_SUP_SHIFT) 4650*4882a593Smuzhiyun 4651*4882a593Smuzhiyun /* VHT CAP INFO extended NSS BW support - refer to IEEE 802.11 REVmc D8.0 Figure 9-559 */ 4652*4882a593Smuzhiyun #define VHT_CAP_INFO_EXT_NSS_BW_HALF_160 1 /* 160MHz at half NSS CAP */ 4653*4882a593Smuzhiyun #define VHT_CAP_INFO_EXT_NSS_BW_HALF_160_80P80 2 /* 160 & 80p80 MHz at half NSS CAP */ 4654*4882a593Smuzhiyun 4655*4882a593Smuzhiyun /* VHT Supported MCS Set - 64-bit - in VHT Cap IE */ 4656*4882a593Smuzhiyun #define VHT_CAP_SUPP_MCS_RX_HIGHEST_RATE_MASK 0x1fff 4657*4882a593Smuzhiyun #define VHT_CAP_SUPP_MCS_RX_HIGHEST_RATE_SHIFT 0 4658*4882a593Smuzhiyun 4659*4882a593Smuzhiyun #define VHT_CAP_SUPP_MCS_TX_HIGHEST_RATE_MASK 0x1fff 4660*4882a593Smuzhiyun #define VHT_CAP_SUPP_MCS_TX_HIGHEST_RATE_SHIFT 0 4661*4882a593Smuzhiyun 4662*4882a593Smuzhiyun /* defines for field(s) in vht_cap_ie->rx_max_rate */ 4663*4882a593Smuzhiyun #define VHT_CAP_MAX_NSTS_MASK 0xe000 4664*4882a593Smuzhiyun #define VHT_CAP_MAX_NSTS_SHIFT 13 4665*4882a593Smuzhiyun 4666*4882a593Smuzhiyun /* defines for field(s) in vht_cap_ie->tx_max_rate */ 4667*4882a593Smuzhiyun #define VHT_CAP_EXT_NSS_BW_CAP 0x2000 4668*4882a593Smuzhiyun 4669*4882a593Smuzhiyun #define VHT_CAP_MCS_MAP_0_7 0 4670*4882a593Smuzhiyun #define VHT_CAP_MCS_MAP_0_8 1 4671*4882a593Smuzhiyun #define VHT_CAP_MCS_MAP_0_9 2 4672*4882a593Smuzhiyun #define VHT_CAP_MCS_MAP_NONE 3 4673*4882a593Smuzhiyun #define VHT_CAP_MCS_MAP_S 2 /* num bits for 1-stream */ 4674*4882a593Smuzhiyun #define VHT_CAP_MCS_MAP_M 0x3 /* mask for 1-stream */ 4675*4882a593Smuzhiyun /* assumes VHT_CAP_MCS_MAP_NONE is 3 and 2 bits are used for encoding */ 4676*4882a593Smuzhiyun #define VHT_CAP_MCS_MAP_NONE_ALL 0xffff 4677*4882a593Smuzhiyun 4678*4882a593Smuzhiyun /* VHT rates bitmap */ 4679*4882a593Smuzhiyun #define VHT_CAP_MCS_0_7_RATEMAP 0x00ff 4680*4882a593Smuzhiyun #define VHT_CAP_MCS_0_8_RATEMAP 0x01ff 4681*4882a593Smuzhiyun #define VHT_CAP_MCS_0_9_RATEMAP 0x03ff 4682*4882a593Smuzhiyun #define VHT_CAP_MCS_FULL_RATEMAP VHT_CAP_MCS_0_9_RATEMAP 4683*4882a593Smuzhiyun 4684*4882a593Smuzhiyun #define VHT_PROP_MCS_MAP_10_11 0 4685*4882a593Smuzhiyun #define VHT_PROP_MCS_MAP_UNUSED1 1 4686*4882a593Smuzhiyun #define VHT_PROP_MCS_MAP_UNUSED2 2 4687*4882a593Smuzhiyun #define VHT_PROP_MCS_MAP_NONE 3 4688*4882a593Smuzhiyun #define VHT_PROP_MCS_MAP_NONE_ALL 0xffff 4689*4882a593Smuzhiyun 4690*4882a593Smuzhiyun /* VHT prop rates bitmap */ 4691*4882a593Smuzhiyun #define VHT_PROP_MCS_10_11_RATEMAP 0x0c00 4692*4882a593Smuzhiyun #define VHT_PROP_MCS_FULL_RATEMAP VHT_PROP_MCS_10_11_RATEMAP 4693*4882a593Smuzhiyun 4694*4882a593Smuzhiyun #if !defined(VHT_CAP_MCS_MAP_0_9_NSS3) 4695*4882a593Smuzhiyun /* remove after moving define to wlc_rate.h */ 4696*4882a593Smuzhiyun /* mcsmap with MCS0-9 for Nss = 3 */ 4697*4882a593Smuzhiyun #define VHT_CAP_MCS_MAP_0_9_NSS3 \ 4698*4882a593Smuzhiyun ((VHT_CAP_MCS_MAP_0_9 << VHT_MCS_MAP_GET_SS_IDX(1)) | \ 4699*4882a593Smuzhiyun (VHT_CAP_MCS_MAP_0_9 << VHT_MCS_MAP_GET_SS_IDX(2)) | \ 4700*4882a593Smuzhiyun (VHT_CAP_MCS_MAP_0_9 << VHT_MCS_MAP_GET_SS_IDX(3))) 4701*4882a593Smuzhiyun #endif /* !VHT_CAP_MCS_MAP_0_9_NSS3 */ 4702*4882a593Smuzhiyun 4703*4882a593Smuzhiyun #define VHT_CAP_MCS_MAP_NSS_MAX 8 4704*4882a593Smuzhiyun 4705*4882a593Smuzhiyun /* get mcsmap with given mcs for given nss streams */ 4706*4882a593Smuzhiyun #define VHT_CAP_MCS_MAP_CREATE(mcsmap, nss, mcs) \ 4707*4882a593Smuzhiyun do { \ 4708*4882a593Smuzhiyun int i; \ 4709*4882a593Smuzhiyun for (i = 1; i <= nss; i++) { \ 4710*4882a593Smuzhiyun VHT_MCS_MAP_SET_MCS_PER_SS(i, mcs, mcsmap); \ 4711*4882a593Smuzhiyun } \ 4712*4882a593Smuzhiyun } while (0) 4713*4882a593Smuzhiyun 4714*4882a593Smuzhiyun /* Map the mcs code to mcs bit map */ 4715*4882a593Smuzhiyun #define VHT_MCS_CODE_TO_MCS_MAP(mcs_code) \ 4716*4882a593Smuzhiyun ((mcs_code == VHT_CAP_MCS_MAP_0_7) ? VHT_CAP_MCS_0_7_RATEMAP : \ 4717*4882a593Smuzhiyun (mcs_code == VHT_CAP_MCS_MAP_0_8) ? VHT_CAP_MCS_0_8_RATEMAP : \ 4718*4882a593Smuzhiyun (mcs_code == VHT_CAP_MCS_MAP_0_9) ? VHT_CAP_MCS_0_9_RATEMAP : 0) 4719*4882a593Smuzhiyun 4720*4882a593Smuzhiyun /* Map the proprietary mcs code to proprietary mcs bitmap */ 4721*4882a593Smuzhiyun #define VHT_PROP_MCS_CODE_TO_PROP_MCS_MAP(mcs_code) \ 4722*4882a593Smuzhiyun ((mcs_code == VHT_PROP_MCS_MAP_10_11) ? VHT_PROP_MCS_10_11_RATEMAP : 0) 4723*4882a593Smuzhiyun 4724*4882a593Smuzhiyun /* Map the mcs bit map to mcs code */ 4725*4882a593Smuzhiyun #define VHT_MCS_MAP_TO_MCS_CODE(mcs_map) \ 4726*4882a593Smuzhiyun ((mcs_map == VHT_CAP_MCS_0_7_RATEMAP) ? VHT_CAP_MCS_MAP_0_7 : \ 4727*4882a593Smuzhiyun (mcs_map == VHT_CAP_MCS_0_8_RATEMAP) ? VHT_CAP_MCS_MAP_0_8 : \ 4728*4882a593Smuzhiyun (mcs_map == VHT_CAP_MCS_0_9_RATEMAP) ? VHT_CAP_MCS_MAP_0_9 : VHT_CAP_MCS_MAP_NONE) 4729*4882a593Smuzhiyun 4730*4882a593Smuzhiyun /* Map the proprietary mcs map to proprietary mcs code */ 4731*4882a593Smuzhiyun #define VHT_PROP_MCS_MAP_TO_PROP_MCS_CODE(mcs_map) \ 4732*4882a593Smuzhiyun (((mcs_map & 0xc00) == 0xc00) ? VHT_PROP_MCS_MAP_10_11 : VHT_PROP_MCS_MAP_NONE) 4733*4882a593Smuzhiyun 4734*4882a593Smuzhiyun /** VHT Capabilities Supported Channel Width */ 4735*4882a593Smuzhiyun typedef enum vht_cap_chan_width { 4736*4882a593Smuzhiyun VHT_CAP_CHAN_WIDTH_SUPPORT_MANDATORY = 0x00, 4737*4882a593Smuzhiyun VHT_CAP_CHAN_WIDTH_SUPPORT_160 = 0x04, 4738*4882a593Smuzhiyun VHT_CAP_CHAN_WIDTH_SUPPORT_160_8080 = 0x08 4739*4882a593Smuzhiyun } vht_cap_chan_width_t; 4740*4882a593Smuzhiyun 4741*4882a593Smuzhiyun /** VHT Capabilities Supported max MPDU LEN (sec 8.4.2.160.2) */ 4742*4882a593Smuzhiyun typedef enum vht_cap_max_mpdu_len { 4743*4882a593Smuzhiyun VHT_CAP_MPDU_MAX_4K = 0x00, 4744*4882a593Smuzhiyun VHT_CAP_MPDU_MAX_8K = 0x01, 4745*4882a593Smuzhiyun VHT_CAP_MPDU_MAX_11K = 0x02 4746*4882a593Smuzhiyun } vht_cap_max_mpdu_len_t; 4747*4882a593Smuzhiyun 4748*4882a593Smuzhiyun /* Maximum MPDU Length byte counts for the VHT Capabilities advertised limits */ 4749*4882a593Smuzhiyun #define VHT_MPDU_LIMIT_4K 3895 4750*4882a593Smuzhiyun #define VHT_MPDU_LIMIT_8K 7991 4751*4882a593Smuzhiyun #define VHT_MPDU_LIMIT_11K 11454 4752*4882a593Smuzhiyun 4753*4882a593Smuzhiyun /** 4754*4882a593Smuzhiyun * VHT Operation IE (sec 8.4.2.161) 4755*4882a593Smuzhiyun */ 4756*4882a593Smuzhiyun 4757*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct vht_op_ie { 4758*4882a593Smuzhiyun uint8 chan_width; 4759*4882a593Smuzhiyun uint8 chan1; 4760*4882a593Smuzhiyun uint8 chan2; 4761*4882a593Smuzhiyun uint16 supp_mcs; /* same def as above in vht cap */ 4762*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 4763*4882a593Smuzhiyun typedef struct vht_op_ie vht_op_ie_t; 4764*4882a593Smuzhiyun 4765*4882a593Smuzhiyun /* 3B VHT Op info + 2B Basic MCS */ 4766*4882a593Smuzhiyun #define VHT_OP_IE_LEN 5 4767*4882a593Smuzhiyun 4768*4882a593Smuzhiyun typedef enum vht_op_chan_width { 4769*4882a593Smuzhiyun VHT_OP_CHAN_WIDTH_20_40 = 0, 4770*4882a593Smuzhiyun VHT_OP_CHAN_WIDTH_80 = 1, 4771*4882a593Smuzhiyun VHT_OP_CHAN_WIDTH_160 = 2, /* deprecated - IEEE 802.11 REVmc D8.0 Table 11-25 */ 4772*4882a593Smuzhiyun VHT_OP_CHAN_WIDTH_80_80 = 3 /* deprecated - IEEE 802.11 REVmc D8.0 Table 11-25 */ 4773*4882a593Smuzhiyun } vht_op_chan_width_t; 4774*4882a593Smuzhiyun 4775*4882a593Smuzhiyun #define VHT_OP_INFO_LEN 3 4776*4882a593Smuzhiyun 4777*4882a593Smuzhiyun /* AID length */ 4778*4882a593Smuzhiyun #define AID_IE_LEN 2 4779*4882a593Smuzhiyun /** 4780*4882a593Smuzhiyun * BRCM vht features IE header 4781*4882a593Smuzhiyun * The header if the fixed part of the IE 4782*4882a593Smuzhiyun * On the 5GHz band this is the entire IE, 4783*4882a593Smuzhiyun * on 2.4GHz the VHT IEs as defined in the 802.11ac 4784*4882a593Smuzhiyun * specification follows 4785*4882a593Smuzhiyun * 4786*4882a593Smuzhiyun * 4787*4882a593Smuzhiyun * VHT features rates bitmap. 4788*4882a593Smuzhiyun * Bit0: 5G MCS 0-9 BW 160MHz 4789*4882a593Smuzhiyun * Bit1: 5G MCS 0-9 support BW 80MHz 4790*4882a593Smuzhiyun * Bit2: 5G MCS 0-9 support BW 20MHz 4791*4882a593Smuzhiyun * Bit3: 2.4G MCS 0-9 support BW 20MHz 4792*4882a593Smuzhiyun * Bits:4-7 Reserved for future use 4793*4882a593Smuzhiyun * 4794*4882a593Smuzhiyun */ 4795*4882a593Smuzhiyun #define VHT_FEATURES_IE_TYPE 0x4 4796*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct vht_features_ie_hdr { 4797*4882a593Smuzhiyun uint8 oui[3]; /* Proprietary OUI, BRCM_PROP_OUI */ 4798*4882a593Smuzhiyun uint8 type; /* type of this IE = 4 */ 4799*4882a593Smuzhiyun uint8 rate_mask; /* VHT rate mask */ 4800*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 4801*4882a593Smuzhiyun typedef struct vht_features_ie_hdr vht_features_ie_hdr_t; 4802*4882a593Smuzhiyun 4803*4882a593Smuzhiyun /* Def for rx & tx basic mcs maps - ea ss num has 2 bits of info */ 4804*4882a593Smuzhiyun #define VHT_MCS_MAP_GET_SS_IDX(nss) (((nss)-1) * VHT_CAP_MCS_MAP_S) 4805*4882a593Smuzhiyun #define VHT_MCS_MAP_GET_MCS_PER_SS(nss, mcsMap) \ 4806*4882a593Smuzhiyun (((mcsMap) >> VHT_MCS_MAP_GET_SS_IDX(nss)) & VHT_CAP_MCS_MAP_M) 4807*4882a593Smuzhiyun #define VHT_MCS_MAP_SET_MCS_PER_SS(nss, numMcs, mcsMap) \ 4808*4882a593Smuzhiyun do { \ 4809*4882a593Smuzhiyun (mcsMap) &= (~(VHT_CAP_MCS_MAP_M << VHT_MCS_MAP_GET_SS_IDX(nss))); \ 4810*4882a593Smuzhiyun (mcsMap) |= (((numMcs) & VHT_CAP_MCS_MAP_M) << VHT_MCS_MAP_GET_SS_IDX(nss)); \ 4811*4882a593Smuzhiyun } while (0) 4812*4882a593Smuzhiyun #define VHT_MCS_SS_SUPPORTED(nss, mcsMap) \ 4813*4882a593Smuzhiyun (VHT_MCS_MAP_GET_MCS_PER_SS((nss), (mcsMap)) != VHT_CAP_MCS_MAP_NONE) 4814*4882a593Smuzhiyun 4815*4882a593Smuzhiyun /* Get the max ss supported from the mcs map */ 4816*4882a593Smuzhiyun #define VHT_MAX_SS_SUPPORTED(mcsMap) \ 4817*4882a593Smuzhiyun VHT_MCS_SS_SUPPORTED(8, mcsMap) ? 8 : \ 4818*4882a593Smuzhiyun VHT_MCS_SS_SUPPORTED(7, mcsMap) ? 7 : \ 4819*4882a593Smuzhiyun VHT_MCS_SS_SUPPORTED(6, mcsMap) ? 6 : \ 4820*4882a593Smuzhiyun VHT_MCS_SS_SUPPORTED(5, mcsMap) ? 5 : \ 4821*4882a593Smuzhiyun VHT_MCS_SS_SUPPORTED(4, mcsMap) ? 4 : \ 4822*4882a593Smuzhiyun VHT_MCS_SS_SUPPORTED(3, mcsMap) ? 3 : \ 4823*4882a593Smuzhiyun VHT_MCS_SS_SUPPORTED(2, mcsMap) ? 2 : \ 4824*4882a593Smuzhiyun VHT_MCS_SS_SUPPORTED(1, mcsMap) ? 1 : 0 4825*4882a593Smuzhiyun 4826*4882a593Smuzhiyun #ifdef IBSS_RMC 4827*4882a593Smuzhiyun /* customer's OUI */ 4828*4882a593Smuzhiyun #define RMC_PROP_OUI "\x00\x16\x32" 4829*4882a593Smuzhiyun #endif 4830*4882a593Smuzhiyun 4831*4882a593Smuzhiyun /* ************* WPA definitions. ************* */ 4832*4882a593Smuzhiyun #define WPA_OUI "\x00\x50\xF2" /* WPA OUI */ 4833*4882a593Smuzhiyun #define WPA_OUI_LEN 3 /* WPA OUI length */ 4834*4882a593Smuzhiyun #define WPA_OUI_TYPE 1 4835*4882a593Smuzhiyun #define WPA_VERSION 1 /* WPA version */ 4836*4882a593Smuzhiyun #define WPA_VERSION_LEN 2 /* WPA version length */ 4837*4882a593Smuzhiyun 4838*4882a593Smuzhiyun /* ************* WPA2 definitions. ************* */ 4839*4882a593Smuzhiyun #define WPA2_OUI "\x00\x0F\xAC" /* WPA2 OUI */ 4840*4882a593Smuzhiyun #define WPA2_OUI_LEN 3 /* WPA2 OUI length */ 4841*4882a593Smuzhiyun #define WPA2_VERSION 1 /* WPA2 version */ 4842*4882a593Smuzhiyun #define WPA2_VERSION_LEN 2 /* WAP2 version length */ 4843*4882a593Smuzhiyun #define MAX_RSNE_SUPPORTED_VERSION WPA2_VERSION /* Max supported version */ 4844*4882a593Smuzhiyun 4845*4882a593Smuzhiyun /* ************* WPS definitions. ************* */ 4846*4882a593Smuzhiyun #define WPS_OUI "\x00\x50\xF2" /* WPS OUI */ 4847*4882a593Smuzhiyun #define WPS_OUI_LEN 3 /* WPS OUI length */ 4848*4882a593Smuzhiyun #define WPS_OUI_TYPE 4 4849*4882a593Smuzhiyun 4850*4882a593Smuzhiyun /* ************* TPC definitions. ************* */ 4851*4882a593Smuzhiyun #define TPC_OUI "\x00\x50\xF2" /* TPC OUI */ 4852*4882a593Smuzhiyun #define TPC_OUI_LEN 3 /* TPC OUI length */ 4853*4882a593Smuzhiyun #define TPC_OUI_TYPE 8 4854*4882a593Smuzhiyun #define WFA_OUI_TYPE_TPC 8 /* deprecated */ 4855*4882a593Smuzhiyun 4856*4882a593Smuzhiyun /* ************* WFA definitions. ************* */ 4857*4882a593Smuzhiyun #define WFA_OUI "\x50\x6F\x9A" /* WFA OUI */ 4858*4882a593Smuzhiyun #define WFA_OUI_LEN 3 /* WFA OUI length */ 4859*4882a593Smuzhiyun #define WFA_OUI_TYPE_P2P 9 4860*4882a593Smuzhiyun 4861*4882a593Smuzhiyun /* WFA definitions for LEGACY P2P */ 4862*4882a593Smuzhiyun #ifdef WL_LEGACY_P2P 4863*4882a593Smuzhiyun #define APPLE_OUI "\x00\x17\xF2" /* MACOSX OUI */ 4864*4882a593Smuzhiyun #define APPLE_OUI_LEN 3 4865*4882a593Smuzhiyun #define APPLE_OUI_TYPE_P2P 5 4866*4882a593Smuzhiyun #endif /* WL_LEGACY_P2P */ 4867*4882a593Smuzhiyun 4868*4882a593Smuzhiyun #ifndef WL_LEGACY_P2P 4869*4882a593Smuzhiyun #define P2P_OUI WFA_OUI 4870*4882a593Smuzhiyun #define P2P_OUI_LEN WFA_OUI_LEN 4871*4882a593Smuzhiyun #define P2P_OUI_TYPE WFA_OUI_TYPE_P2P 4872*4882a593Smuzhiyun #else 4873*4882a593Smuzhiyun #define P2P_OUI APPLE_OUI 4874*4882a593Smuzhiyun #define P2P_OUI_LEN APPLE_OUI_LEN 4875*4882a593Smuzhiyun #define P2P_OUI_TYPE APPLE_OUI_TYPE_P2P 4876*4882a593Smuzhiyun #endif /* !WL_LEGACY_P2P */ 4877*4882a593Smuzhiyun 4878*4882a593Smuzhiyun #ifdef WLTDLS 4879*4882a593Smuzhiyun #define WFA_OUI_TYPE_TPQ 4 /* WFD Tunneled Probe ReQuest */ 4880*4882a593Smuzhiyun #define WFA_OUI_TYPE_TPS 5 /* WFD Tunneled Probe ReSponse */ 4881*4882a593Smuzhiyun #define WFA_OUI_TYPE_WFD 10 4882*4882a593Smuzhiyun #endif /* WTDLS */ 4883*4882a593Smuzhiyun #define WFA_OUI_TYPE_HS20 0x10 4884*4882a593Smuzhiyun #define WFA_OUI_TYPE_OSEN 0x12 4885*4882a593Smuzhiyun #define WFA_OUI_TYPE_NAN 0x13 4886*4882a593Smuzhiyun #define WFA_OUI_TYPE_MBO 0x16 4887*4882a593Smuzhiyun #define WFA_OUI_TYPE_MBO_OCE 0x16 4888*4882a593Smuzhiyun #define WFA_OUI_TYPE_OWE 0x1C 4889*4882a593Smuzhiyun #define WFA_OUI_TYPE_SAE_PK 0x1F 4890*4882a593Smuzhiyun #define WFA_OUI_TYPE_TD_INDICATION 0x20 4891*4882a593Smuzhiyun 4892*4882a593Smuzhiyun #define SAE_PK_MOD_LEN 32u 4893*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_sae_pk_element { 4894*4882a593Smuzhiyun uint8 id; /* IE ID, 221, DOT11_MNG_PROPR_ID */ 4895*4882a593Smuzhiyun uint8 len; /* IE length */ 4896*4882a593Smuzhiyun uint8 oui[WFA_OUI_LEN]; /* WFA_OUI */ 4897*4882a593Smuzhiyun uint8 type; /* SAE-PK */ 4898*4882a593Smuzhiyun uint8 data[SAE_PK_MOD_LEN]; /* Modifier. 32Byte fixed */ 4899*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 4900*4882a593Smuzhiyun typedef struct dot11_sae_pk_element dot11_sae_pk_element_t; 4901*4882a593Smuzhiyun 4902*4882a593Smuzhiyun /* RSN authenticated key managment suite */ 4903*4882a593Smuzhiyun #define RSN_AKM_NONE 0 /* None (IBSS) */ 4904*4882a593Smuzhiyun #define RSN_AKM_UNSPECIFIED 1 /* Over 802.1x */ 4905*4882a593Smuzhiyun #define RSN_AKM_PSK 2 /* Pre-shared Key */ 4906*4882a593Smuzhiyun #define RSN_AKM_FBT_1X 3 /* Fast Bss transition using 802.1X */ 4907*4882a593Smuzhiyun #define RSN_AKM_FBT_PSK 4 /* Fast Bss transition using Pre-shared Key */ 4908*4882a593Smuzhiyun /* RSN_AKM_MFP_1X and RSN_AKM_MFP_PSK are not used any more 4909*4882a593Smuzhiyun * Just kept here to avoid build issue in BISON/CARIBOU branch 4910*4882a593Smuzhiyun */ 4911*4882a593Smuzhiyun #define RSN_AKM_MFP_1X 5 /* SHA256 key derivation, using 802.1X */ 4912*4882a593Smuzhiyun #define RSN_AKM_MFP_PSK 6 /* SHA256 key derivation, using Pre-shared Key */ 4913*4882a593Smuzhiyun #define RSN_AKM_SHA256_1X 5 /* SHA256 key derivation, using 802.1X */ 4914*4882a593Smuzhiyun #define RSN_AKM_SHA256_PSK 6 /* SHA256 key derivation, using Pre-shared Key */ 4915*4882a593Smuzhiyun #define RSN_AKM_TPK 7 /* TPK(TDLS Peer Key) handshake */ 4916*4882a593Smuzhiyun #define RSN_AKM_SAE_PSK 8 /* AKM for SAE with 4-way handshake */ 4917*4882a593Smuzhiyun #define RSN_AKM_SAE_FBT 9 /* AKM for SAE with FBT */ 4918*4882a593Smuzhiyun #define RSN_AKM_SUITEB_SHA256_1X 11 /* Suite B SHA256 */ 4919*4882a593Smuzhiyun #define RSN_AKM_SUITEB_SHA384_1X 12 /* Suite B-192 SHA384 */ 4920*4882a593Smuzhiyun #define RSN_AKM_FBT_SHA384_1X 13 /* FBT SHA384 */ 4921*4882a593Smuzhiyun #define RSN_AKM_FILS_SHA256 14 /* SHA256 key derivation, using FILS */ 4922*4882a593Smuzhiyun #define RSN_AKM_FILS_SHA384 15 /* SHA384 key derivation, using FILS */ 4923*4882a593Smuzhiyun #define RSN_AKM_FBT_SHA256_FILS 16 4924*4882a593Smuzhiyun #define RSN_AKM_FBT_SHA384_FILS 17 4925*4882a593Smuzhiyun #define RSN_AKM_OWE 18 /* RFC 8110 OWE */ 4926*4882a593Smuzhiyun #define RSN_AKM_FBT_SHA384_PSK 19 4927*4882a593Smuzhiyun #define RSN_AKM_PSK_SHA384 20 4928*4882a593Smuzhiyun /* OSEN authenticated key managment suite */ 4929*4882a593Smuzhiyun #define OSEN_AKM_UNSPECIFIED RSN_AKM_UNSPECIFIED /* Over 802.1x */ 4930*4882a593Smuzhiyun /* WFA DPP RSN authenticated key managment */ 4931*4882a593Smuzhiyun #define RSN_AKM_DPP 02u /* DPP RSN */ 4932*4882a593Smuzhiyun 4933*4882a593Smuzhiyun /* Key related defines */ 4934*4882a593Smuzhiyun #define DOT11_MAX_DEFAULT_KEYS 4 /* number of default keys */ 4935*4882a593Smuzhiyun #define DOT11_MAX_IGTK_KEYS 2 4936*4882a593Smuzhiyun #define DOT11_MAX_BIGTK_KEYS 2 4937*4882a593Smuzhiyun #define DOT11_MAX_KEY_SIZE 32 /* max size of any key */ 4938*4882a593Smuzhiyun #define DOT11_MAX_IV_SIZE 16 /* max size of any IV */ 4939*4882a593Smuzhiyun #define DOT11_EXT_IV_FLAG (1<<5) /* flag to indicate IV is > 4 bytes */ 4940*4882a593Smuzhiyun #define DOT11_WPA_KEY_RSC_LEN 8 /* WPA RSC key len */ 4941*4882a593Smuzhiyun 4942*4882a593Smuzhiyun #define WEP1_KEY_SIZE 5 /* max size of any WEP key */ 4943*4882a593Smuzhiyun #define WEP1_KEY_HEX_SIZE 10 /* size of WEP key in hex. */ 4944*4882a593Smuzhiyun #define WEP128_KEY_SIZE 13 /* max size of any WEP key */ 4945*4882a593Smuzhiyun #define WEP128_KEY_HEX_SIZE 26 /* size of WEP key in hex. */ 4946*4882a593Smuzhiyun #define TKIP_MIC_SIZE 8 /* size of TKIP MIC */ 4947*4882a593Smuzhiyun #define TKIP_EOM_SIZE 7 /* max size of TKIP EOM */ 4948*4882a593Smuzhiyun #define TKIP_EOM_FLAG 0x5a /* TKIP EOM flag byte */ 4949*4882a593Smuzhiyun #define TKIP_KEY_SIZE 32 /* size of any TKIP key, includs MIC keys */ 4950*4882a593Smuzhiyun #define TKIP_TK_SIZE 16 4951*4882a593Smuzhiyun #define TKIP_MIC_KEY_SIZE 8 4952*4882a593Smuzhiyun #define TKIP_MIC_AUTH_TX 16 /* offset to Authenticator MIC TX key */ 4953*4882a593Smuzhiyun #define TKIP_MIC_AUTH_RX 24 /* offset to Authenticator MIC RX key */ 4954*4882a593Smuzhiyun #define TKIP_MIC_SUP_RX TKIP_MIC_AUTH_TX /* offset to Supplicant MIC RX key */ 4955*4882a593Smuzhiyun #define TKIP_MIC_SUP_TX TKIP_MIC_AUTH_RX /* offset to Supplicant MIC TX key */ 4956*4882a593Smuzhiyun #define AES_KEY_SIZE 16 /* size of AES key */ 4957*4882a593Smuzhiyun #define AES_MIC_SIZE 8 /* size of AES MIC */ 4958*4882a593Smuzhiyun #define BIP_KEY_SIZE 16 /* size of BIP key */ 4959*4882a593Smuzhiyun #define BIP_MIC_SIZE 8 /* sizeof BIP MIC */ 4960*4882a593Smuzhiyun 4961*4882a593Smuzhiyun #define AES_GCM_MIC_SIZE 16 /* size of MIC for 128-bit GCM - .11adD9 */ 4962*4882a593Smuzhiyun 4963*4882a593Smuzhiyun #define AES256_KEY_SIZE 32 /* size of AES 256 key - .11acD5 */ 4964*4882a593Smuzhiyun #define AES256_MIC_SIZE 16 /* size of MIC for 256 bit keys, incl BIP */ 4965*4882a593Smuzhiyun 4966*4882a593Smuzhiyun /* WCN */ 4967*4882a593Smuzhiyun #define WCN_OUI "\x00\x50\xf2" /* WCN OUI */ 4968*4882a593Smuzhiyun #define WCN_TYPE 4 /* WCN type */ 4969*4882a593Smuzhiyun 4970*4882a593Smuzhiyun #ifdef BCMWAPI_WPI 4971*4882a593Smuzhiyun #define SMS4_KEY_LEN 16 4972*4882a593Smuzhiyun #define SMS4_WPI_CBC_MAC_LEN 16 4973*4882a593Smuzhiyun #endif 4974*4882a593Smuzhiyun 4975*4882a593Smuzhiyun /* 802.11r protocol definitions */ 4976*4882a593Smuzhiyun 4977*4882a593Smuzhiyun /** Mobility Domain IE */ 4978*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_mdid_ie { 4979*4882a593Smuzhiyun uint8 id; 4980*4882a593Smuzhiyun uint8 len; /* DOT11_MDID_IE_DATA_LEN (3) */ 4981*4882a593Smuzhiyun uint16 mdid; /* Mobility Domain Id */ 4982*4882a593Smuzhiyun uint8 cap; 4983*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 4984*4882a593Smuzhiyun typedef struct dot11_mdid_ie dot11_mdid_ie_t; 4985*4882a593Smuzhiyun 4986*4882a593Smuzhiyun /* length of data portion of Mobility Domain IE */ 4987*4882a593Smuzhiyun #define DOT11_MDID_IE_DATA_LEN 3 4988*4882a593Smuzhiyun #define DOT11_MDID_LEN 2 4989*4882a593Smuzhiyun #define FBT_MDID_CAP_OVERDS 0x01 /* Fast Bss transition over the DS support */ 4990*4882a593Smuzhiyun #define FBT_MDID_CAP_RRP 0x02 /* Resource request protocol support */ 4991*4882a593Smuzhiyun 4992*4882a593Smuzhiyun /* BITs in FTIE mic control field */ 4993*4882a593Smuzhiyun #define DOT11_FTIE_RSNXE_USED 0x1u 4994*4882a593Smuzhiyun 4995*4882a593Smuzhiyun /* Fast Bss Transition IE */ 4996*4882a593Smuzhiyun #ifdef FT_IE_VER_V2 4997*4882a593Smuzhiyun typedef BWL_PRE_PACKED_STRUCT struct dot11_ft_ie_v2 { 4998*4882a593Smuzhiyun uint8 id; 4999*4882a593Smuzhiyun uint8 len; 5000*4882a593Smuzhiyun uint16 mic_control; 5001*4882a593Smuzhiyun /* dynamic offset to following mic[], anonce[], snonce[] */ 5002*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT dot11_ft_ie_v2; 5003*4882a593Smuzhiyun typedef struct dot11_ft_ie_v2 dot11_ft_ie_t; 5004*4882a593Smuzhiyun #else 5005*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ft_ie { 5006*4882a593Smuzhiyun uint8 id; 5007*4882a593Smuzhiyun uint8 len; /* At least equal to DOT11_FT_IE_FIXED_LEN (82) */ 5008*4882a593Smuzhiyun uint16 mic_control; /* Mic Control */ 5009*4882a593Smuzhiyun uint8 mic[16]; 5010*4882a593Smuzhiyun uint8 anonce[32]; 5011*4882a593Smuzhiyun uint8 snonce[32]; 5012*4882a593Smuzhiyun /* Optional sub-elements follow */ 5013*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5014*4882a593Smuzhiyun typedef struct dot11_ft_ie dot11_ft_ie_t; 5015*4882a593Smuzhiyun 5016*4882a593Smuzhiyun /* Fixed length of data portion of Fast BSS Transition IE. There could be 5017*4882a593Smuzhiyun * optional parameters, which if present, could raise the FT IE length to 255. 5018*4882a593Smuzhiyun */ 5019*4882a593Smuzhiyun #define DOT11_FT_IE_FIXED_LEN 82 5020*4882a593Smuzhiyun #endif /* FT_IE_VER_V2 */ 5021*4882a593Smuzhiyun 5022*4882a593Smuzhiyun #ifdef FT_IE_VER_V2 5023*4882a593Smuzhiyun #define DOT11_FT_IE_LEN(mic_len) (sizeof(dot11_ft_ie_v2) + mic_len + EAPOL_WPA_KEY_NONCE_LEN *2) 5024*4882a593Smuzhiyun #define FT_IE_MIC(pos) ((uint8 *)pos + sizeof(dot11_ft_ie_v2)) 5025*4882a593Smuzhiyun #define FT_IE_ANONCE(pos, mic_len) ((uint8 *)pos + sizeof(dot11_ft_ie_v2) + mic_len) 5026*4882a593Smuzhiyun #define FT_IE_SNONCE(pos, mic_len) ((uint8 *)pos + sizeof(dot11_ft_ie_v2) + mic_len + \ 5027*4882a593Smuzhiyun EAPOL_WPA_KEY_NONCE_LEN) 5028*4882a593Smuzhiyun #else 5029*4882a593Smuzhiyun #define DOT11_FT_IE_LEN(mic_len) sizeof(dot11_ft_ie) 5030*4882a593Smuzhiyun #define FT_IE_MIC(pos) ((uint8 *)&pos->mic) 5031*4882a593Smuzhiyun #define FT_IE_ANONCE(pos, mic_len) ((uint8 *)&pos->anonce) 5032*4882a593Smuzhiyun #define FT_IE_SNONCE(pos, mic_len) ((uint8 *)&pos->snonce) 5033*4882a593Smuzhiyun #endif /* FT_IE_VER_V2 */ 5034*4882a593Smuzhiyun #define TIE_TYPE_RESERVED 0 5035*4882a593Smuzhiyun #define TIE_TYPE_REASSOC_DEADLINE 1 5036*4882a593Smuzhiyun #define TIE_TYPE_KEY_LIEFTIME 2 5037*4882a593Smuzhiyun #define TIE_TYPE_ASSOC_COMEBACK 3 5038*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_timeout_ie { 5039*4882a593Smuzhiyun uint8 id; 5040*4882a593Smuzhiyun uint8 len; 5041*4882a593Smuzhiyun uint8 type; /* timeout interval type */ 5042*4882a593Smuzhiyun uint32 value; /* timeout interval value */ 5043*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5044*4882a593Smuzhiyun typedef struct dot11_timeout_ie dot11_timeout_ie_t; 5045*4882a593Smuzhiyun 5046*4882a593Smuzhiyun /** GTK ie */ 5047*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_gtk_ie { 5048*4882a593Smuzhiyun uint8 id; 5049*4882a593Smuzhiyun uint8 len; 5050*4882a593Smuzhiyun uint16 key_info; 5051*4882a593Smuzhiyun uint8 key_len; 5052*4882a593Smuzhiyun uint8 rsc[8]; 5053*4882a593Smuzhiyun uint8 data[1]; 5054*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5055*4882a593Smuzhiyun typedef struct dot11_gtk_ie dot11_gtk_ie_t; 5056*4882a593Smuzhiyun 5057*4882a593Smuzhiyun /** Management MIC ie */ 5058*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct mmic_ie { 5059*4882a593Smuzhiyun uint8 id; /* IE ID: DOT11_MNG_MMIE_ID */ 5060*4882a593Smuzhiyun uint8 len; /* IE length */ 5061*4882a593Smuzhiyun uint16 key_id; /* key id */ 5062*4882a593Smuzhiyun uint8 ipn[6]; /* ipn */ 5063*4882a593Smuzhiyun uint8 mic[16]; /* mic */ 5064*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5065*4882a593Smuzhiyun typedef struct mmic_ie mmic_ie_t; 5066*4882a593Smuzhiyun 5067*4882a593Smuzhiyun #define DOT11_MMIC_IE_HDR_SIZE (OFFSETOF(mmic_ie_t, mic)) 5068*4882a593Smuzhiyun 5069*4882a593Smuzhiyun /* 802.11r-2008, 11A.10.3 - RRB frame format */ 5070*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ft_rrb_frame { 5071*4882a593Smuzhiyun uint8 frame_type; /* 1 for RRB */ 5072*4882a593Smuzhiyun uint8 packet_type; /* 0 for Request 1 for Response */ 5073*4882a593Smuzhiyun uint16 len; 5074*4882a593Smuzhiyun uint8 cur_ap_addr[ETHER_ADDR_LEN]; 5075*4882a593Smuzhiyun uint8 data[1]; /* IEs Received/Sent in FT Action Req/Resp Frame */ 5076*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5077*4882a593Smuzhiyun 5078*4882a593Smuzhiyun typedef struct dot11_ft_rrb_frame dot11_ft_rrb_frame_t; 5079*4882a593Smuzhiyun 5080*4882a593Smuzhiyun #define DOT11_FT_RRB_FIXED_LEN 10 5081*4882a593Smuzhiyun #define DOT11_FT_REMOTE_FRAME_TYPE 1 5082*4882a593Smuzhiyun #define DOT11_FT_PACKET_REQ 0 5083*4882a593Smuzhiyun #define DOT11_FT_PACKET_RESP 1 5084*4882a593Smuzhiyun 5085*4882a593Smuzhiyun #define BSSID_INVALID "\x00\x00\x00\x00\x00\x00" 5086*4882a593Smuzhiyun #define BSSID_BROADCAST "\xFF\xFF\xFF\xFF\xFF\xFF" 5087*4882a593Smuzhiyun 5088*4882a593Smuzhiyun #ifdef BCMWAPI_WAI 5089*4882a593Smuzhiyun #define WAPI_IE_MIN_LEN 20 /* WAPI IE min length */ 5090*4882a593Smuzhiyun #define WAPI_VERSION 1 /* WAPI version */ 5091*4882a593Smuzhiyun #define WAPI_VERSION_LEN 2 /* WAPI version length */ 5092*4882a593Smuzhiyun #define WAPI_OUI "\x00\x14\x72" /* WAPI OUI */ 5093*4882a593Smuzhiyun #define WAPI_OUI_LEN DOT11_OUI_LEN /* WAPI OUI length */ 5094*4882a593Smuzhiyun #endif /* BCMWAPI_WAI */ 5095*4882a593Smuzhiyun 5096*4882a593Smuzhiyun /* ************* WMM Parameter definitions. ************* */ 5097*4882a593Smuzhiyun #define WMM_OUI "\x00\x50\xF2" /* WNN OUI */ 5098*4882a593Smuzhiyun #define WMM_OUI_LEN 3 /* WMM OUI length */ 5099*4882a593Smuzhiyun #define WMM_OUI_TYPE 2 /* WMM OUT type */ 5100*4882a593Smuzhiyun #define WMM_VERSION 1 5101*4882a593Smuzhiyun #define WMM_VERSION_LEN 1 5102*4882a593Smuzhiyun 5103*4882a593Smuzhiyun /* WMM OUI subtype */ 5104*4882a593Smuzhiyun #define WMM_OUI_SUBTYPE_PARAMETER 1 5105*4882a593Smuzhiyun #define WMM_PARAMETER_IE_LEN 24 5106*4882a593Smuzhiyun 5107*4882a593Smuzhiyun /** Link Identifier Element */ 5108*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct link_id_ie { 5109*4882a593Smuzhiyun uint8 id; 5110*4882a593Smuzhiyun uint8 len; 5111*4882a593Smuzhiyun struct ether_addr bssid; 5112*4882a593Smuzhiyun struct ether_addr tdls_init_mac; 5113*4882a593Smuzhiyun struct ether_addr tdls_resp_mac; 5114*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5115*4882a593Smuzhiyun typedef struct link_id_ie link_id_ie_t; 5116*4882a593Smuzhiyun #define TDLS_LINK_ID_IE_LEN 18u 5117*4882a593Smuzhiyun 5118*4882a593Smuzhiyun /** Link Wakeup Schedule Element */ 5119*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct wakeup_sch_ie { 5120*4882a593Smuzhiyun uint8 id; 5121*4882a593Smuzhiyun uint8 len; 5122*4882a593Smuzhiyun uint32 offset; /* in ms between TSF0 and start of 1st Awake Window */ 5123*4882a593Smuzhiyun uint32 interval; /* in ms bwtween the start of 2 Awake Windows */ 5124*4882a593Smuzhiyun uint32 awake_win_slots; /* in backof slots, duration of Awake Window */ 5125*4882a593Smuzhiyun uint32 max_wake_win; /* in ms, max duration of Awake Window */ 5126*4882a593Smuzhiyun uint16 idle_cnt; /* number of consecutive Awake Windows */ 5127*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5128*4882a593Smuzhiyun typedef struct wakeup_sch_ie wakeup_sch_ie_t; 5129*4882a593Smuzhiyun #define TDLS_WAKEUP_SCH_IE_LEN 18 5130*4882a593Smuzhiyun 5131*4882a593Smuzhiyun /** Channel Switch Timing Element */ 5132*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct channel_switch_timing_ie { 5133*4882a593Smuzhiyun uint8 id; 5134*4882a593Smuzhiyun uint8 len; 5135*4882a593Smuzhiyun uint16 switch_time; /* in ms, time to switch channels */ 5136*4882a593Smuzhiyun uint16 switch_timeout; /* in ms */ 5137*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5138*4882a593Smuzhiyun typedef struct channel_switch_timing_ie channel_switch_timing_ie_t; 5139*4882a593Smuzhiyun #define TDLS_CHANNEL_SWITCH_TIMING_IE_LEN 4 5140*4882a593Smuzhiyun 5141*4882a593Smuzhiyun /** PTI Control Element */ 5142*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct pti_control_ie { 5143*4882a593Smuzhiyun uint8 id; 5144*4882a593Smuzhiyun uint8 len; 5145*4882a593Smuzhiyun uint8 tid; 5146*4882a593Smuzhiyun uint16 seq_control; 5147*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5148*4882a593Smuzhiyun typedef struct pti_control_ie pti_control_ie_t; 5149*4882a593Smuzhiyun #define TDLS_PTI_CONTROL_IE_LEN 3 5150*4882a593Smuzhiyun 5151*4882a593Smuzhiyun /** PU Buffer Status Element */ 5152*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct pu_buffer_status_ie { 5153*4882a593Smuzhiyun uint8 id; 5154*4882a593Smuzhiyun uint8 len; 5155*4882a593Smuzhiyun uint8 status; 5156*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5157*4882a593Smuzhiyun typedef struct pu_buffer_status_ie pu_buffer_status_ie_t; 5158*4882a593Smuzhiyun #define TDLS_PU_BUFFER_STATUS_IE_LEN 1 5159*4882a593Smuzhiyun #define TDLS_PU_BUFFER_STATUS_AC_BK 1 5160*4882a593Smuzhiyun #define TDLS_PU_BUFFER_STATUS_AC_BE 2 5161*4882a593Smuzhiyun #define TDLS_PU_BUFFER_STATUS_AC_VI 4 5162*4882a593Smuzhiyun #define TDLS_PU_BUFFER_STATUS_AC_VO 8 5163*4882a593Smuzhiyun 5164*4882a593Smuzhiyun /* TDLS Action Field Values */ 5165*4882a593Smuzhiyun #define TDLS_SETUP_REQ 0 5166*4882a593Smuzhiyun #define TDLS_SETUP_RESP 1 5167*4882a593Smuzhiyun #define TDLS_SETUP_CONFIRM 2 5168*4882a593Smuzhiyun #define TDLS_TEARDOWN 3 5169*4882a593Smuzhiyun #define TDLS_PEER_TRAFFIC_IND 4 5170*4882a593Smuzhiyun #define TDLS_CHANNEL_SWITCH_REQ 5 5171*4882a593Smuzhiyun #define TDLS_CHANNEL_SWITCH_RESP 6 5172*4882a593Smuzhiyun #define TDLS_PEER_PSM_REQ 7 5173*4882a593Smuzhiyun #define TDLS_PEER_PSM_RESP 8 5174*4882a593Smuzhiyun #define TDLS_PEER_TRAFFIC_RESP 9 5175*4882a593Smuzhiyun #define TDLS_DISCOVERY_REQ 10 5176*4882a593Smuzhiyun 5177*4882a593Smuzhiyun /* 802.11z TDLS Public Action Frame action field */ 5178*4882a593Smuzhiyun #define TDLS_DISCOVERY_RESP 14 5179*4882a593Smuzhiyun 5180*4882a593Smuzhiyun /* 802.11u GAS action frames */ 5181*4882a593Smuzhiyun #define GAS_REQUEST_ACTION_FRAME 10 5182*4882a593Smuzhiyun #define GAS_RESPONSE_ACTION_FRAME 11 5183*4882a593Smuzhiyun #define GAS_COMEBACK_REQUEST_ACTION_FRAME 12 5184*4882a593Smuzhiyun #define GAS_COMEBACK_RESPONSE_ACTION_FRAME 13 5185*4882a593Smuzhiyun 5186*4882a593Smuzhiyun /* FTM - fine timing measurement public action frames */ 5187*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ftm_req { 5188*4882a593Smuzhiyun uint8 category; /* category of action frame (4) */ 5189*4882a593Smuzhiyun uint8 action; /* public action (32) */ 5190*4882a593Smuzhiyun uint8 trigger; /* trigger/continue? */ 5191*4882a593Smuzhiyun /* optional lci, civic loc, ftm params */ 5192*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5193*4882a593Smuzhiyun typedef struct dot11_ftm_req dot11_ftm_req_t; 5194*4882a593Smuzhiyun 5195*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ftm { 5196*4882a593Smuzhiyun uint8 category; /* category of action frame (4) */ 5197*4882a593Smuzhiyun uint8 action; /* public action (33) */ 5198*4882a593Smuzhiyun uint8 dialog; /* dialog token */ 5199*4882a593Smuzhiyun uint8 follow_up; /* follow up dialog token */ 5200*4882a593Smuzhiyun uint8 tod[6]; /* t1 - last depart timestamp */ 5201*4882a593Smuzhiyun uint8 toa[6]; /* t4 - last ack arrival timestamp */ 5202*4882a593Smuzhiyun uint8 tod_err[2]; /* t1 error */ 5203*4882a593Smuzhiyun uint8 toa_err[2]; /* t4 error */ 5204*4882a593Smuzhiyun /* optional lci report, civic loc report, ftm params */ 5205*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5206*4882a593Smuzhiyun typedef struct dot11_ftm dot11_ftm_t; 5207*4882a593Smuzhiyun 5208*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ftm_lmr { 5209*4882a593Smuzhiyun uint8 category; /* category of action frame (4) */ 5210*4882a593Smuzhiyun uint8 action; /* public action (33) */ 5211*4882a593Smuzhiyun uint8 dialog; /* dialog token */ 5212*4882a593Smuzhiyun uint8 tod[6]; /* RSTA t3 or ISTA t1: 5213*4882a593Smuzhiyun * last departure of NDP 5214*4882a593Smuzhiyun */ 5215*4882a593Smuzhiyun uint8 toa[6]; /* RSTA t2 or ISTA t4: 5216*4882a593Smuzhiyun * last arrival of NDP 5217*4882a593Smuzhiyun */ 5218*4882a593Smuzhiyun uint8 tod_err[2]; /* t3 or t1 error */ 5219*4882a593Smuzhiyun uint8 toa_err[2]; /* t2 or t4 error */ 5220*4882a593Smuzhiyun uint16 cfo; /* I2R LMR: clock difference between ISTA and RSTA. */ 5221*4882a593Smuzhiyun uint8 sec_ltf_params[]; /* Optional Secure LTF parameters */ 5222*4882a593Smuzhiyun /* no AOA feedback */ 5223*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5224*4882a593Smuzhiyun typedef struct dot11_ftm_lmr dot11_ftm_lmr_t; 5225*4882a593Smuzhiyun 5226*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ftm_ranging_ndpa { 5227*4882a593Smuzhiyun uint16 fc; /* frame control */ 5228*4882a593Smuzhiyun uint16 durid; /* duration/ID */ 5229*4882a593Smuzhiyun struct ether_addr ra; /* receiver address */ 5230*4882a593Smuzhiyun struct ether_addr ta; /* transmitter address */ 5231*4882a593Smuzhiyun uint8 dialog_token; /* sounding dialog token */ 5232*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5233*4882a593Smuzhiyun typedef struct dot11_ftm_ranging_ndpa dot11_ftm_ranging_ndpa_t; 5234*4882a593Smuzhiyun 5235*4882a593Smuzhiyun /* NDPA types = dialog token byte lower 2 bits */ 5236*4882a593Smuzhiyun #define DOT11_NDPA_TYPE_MASK 0x03 5237*4882a593Smuzhiyun #define DOT11_NDPA_TYPE_VHT 0x00 5238*4882a593Smuzhiyun #define DOT11_NDPA_TYPE_RANGING 0x01 5239*4882a593Smuzhiyun #define DOT11_NDPA_TYPE_HE 0x02 5240*4882a593Smuzhiyun 5241*4882a593Smuzhiyun #define DOT11_FTM_ERR_NOT_CONT_OFFSET 1 5242*4882a593Smuzhiyun #define DOT11_FTM_ERR_NOT_CONT_MASK 0x80 5243*4882a593Smuzhiyun #define DOT11_FTM_ERR_NOT_CONT_SHIFT 7 5244*4882a593Smuzhiyun #define DOT11_FTM_ERR_NOT_CONT(_err) (((_err)[DOT11_FTM_ERR_NOT_CONT_OFFSET] & \ 5245*4882a593Smuzhiyun DOT11_FTM_ERR_NOT_CONT_MASK) >> DOT11_FTM_ERR_NOT_CONT_SHIFT) 5246*4882a593Smuzhiyun #define DOT11_FTM_ERR_SET_NOT_CONT(_err, _val) do {\ 5247*4882a593Smuzhiyun uint8 _err2 = (_err)[DOT11_FTM_ERR_NOT_CONT_OFFSET]; \ 5248*4882a593Smuzhiyun _err2 &= ~DOT11_FTM_ERR_NOT_CONT_MASK; \ 5249*4882a593Smuzhiyun _err2 |= ((_val) << DOT11_FTM_ERR_NOT_CONT_SHIFT) & DOT11_FTM_ERR_NOT_CONT_MASK; \ 5250*4882a593Smuzhiyun (_err)[DOT11_FTM_ERR_NOT_CONT_OFFSET] = _err2; \ 5251*4882a593Smuzhiyun } while (0) 5252*4882a593Smuzhiyun 5253*4882a593Smuzhiyun #define DOT11_FTM_ERR_MAX_ERR_OFFSET 0 5254*4882a593Smuzhiyun #define DOT11_FTM_ERR_MAX_ERR_MASK 0x7fff 5255*4882a593Smuzhiyun #define DOT11_FTM_ERR_MAX_ERR_SHIFT 0 5256*4882a593Smuzhiyun #define DOT11_FTM_ERR_MAX_ERR(_err) (((((_err)[1] & 0x7f) << 8) | (_err)[0])) 5257*4882a593Smuzhiyun #define DOT11_FTM_ERR_SET_MAX_ERR(_err, _val) do {\ 5258*4882a593Smuzhiyun uint16 _val2; \ 5259*4882a593Smuzhiyun uint16 _not_cont; \ 5260*4882a593Smuzhiyun _val2 = (((_val) & DOT11_FTM_ERR_MAX_ERR_MASK) << DOT11_FTM_ERR_MAX_ERR_SHIFT); \ 5261*4882a593Smuzhiyun _val2 = (_val2 > 0x3fff) ? 0 : _val2; /* not expecting > 16ns error */ \ 5262*4882a593Smuzhiyun _not_cont = DOT11_FTM_ERR_NOT_CONT(_err); \ 5263*4882a593Smuzhiyun (_err)[0] = _val2 & 0xff; \ 5264*4882a593Smuzhiyun (_err)[1] = (_val2 >> 8) & 0xff; \ 5265*4882a593Smuzhiyun DOT11_FTM_ERR_SET_NOT_CONT(_err, _not_cont); \ 5266*4882a593Smuzhiyun } while (0) 5267*4882a593Smuzhiyun 5268*4882a593Smuzhiyun #if defined(DOT11_FTM_ERR_ROM_COMPAT) 5269*4882a593Smuzhiyun /* incorrect defs - here for ROM compatibiity */ 5270*4882a593Smuzhiyun #undef DOT11_FTM_ERR_NOT_CONT_OFFSET 5271*4882a593Smuzhiyun #undef DOT11_FTM_ERR_NOT_CONT_MASK 5272*4882a593Smuzhiyun #undef DOT11_FTM_ERR_NOT_CONT_SHIFT 5273*4882a593Smuzhiyun #undef DOT11_FTM_ERR_NOT_CONT 5274*4882a593Smuzhiyun #undef DOT11_FTM_ERR_SET_NOT_CONT 5275*4882a593Smuzhiyun 5276*4882a593Smuzhiyun #define DOT11_FTM_ERR_NOT_CONT_OFFSET 0 5277*4882a593Smuzhiyun #define DOT11_FTM_ERR_NOT_CONT_MASK 0x0001 5278*4882a593Smuzhiyun #define DOT11_FTM_ERR_NOT_CONT_SHIFT 0 5279*4882a593Smuzhiyun #define DOT11_FTM_ERR_NOT_CONT(_err) (((_err)[DOT11_FTM_ERR_NOT_CONT_OFFSET] & \ 5280*4882a593Smuzhiyun DOT11_FTM_ERR_NOT_CONT_MASK) >> DOT11_FTM_ERR_NOT_CONT_SHIFT) 5281*4882a593Smuzhiyun #define DOT11_FTM_ERR_SET_NOT_CONT(_err, _val) do {\ 5282*4882a593Smuzhiyun uint8 _err2 = (_err)[DOT11_FTM_ERR_NOT_CONT_OFFSET]; \ 5283*4882a593Smuzhiyun _err2 &= ~DOT11_FTM_ERR_NOT_CONT_MASK; \ 5284*4882a593Smuzhiyun _err2 |= ((_val) << DOT11_FTM_ERR_NOT_CONT_SHIFT) & DOT11_FTM_ERR_NOT_CONT_MASK; \ 5285*4882a593Smuzhiyun (_err)[DOT11_FTM_ERR_NOT_CONT_OFFSET] = _err2; \ 5286*4882a593Smuzhiyun } while (0) 5287*4882a593Smuzhiyun 5288*4882a593Smuzhiyun #undef DOT11_FTM_ERR_MAX_ERR_OFFSET 5289*4882a593Smuzhiyun #undef DOT11_FTM_ERR_MAX_ERR_MASK 5290*4882a593Smuzhiyun #undef DOT11_FTM_ERR_MAX_ERR_SHIFT 5291*4882a593Smuzhiyun #undef DOT11_FTM_ERR_MAX_ERR 5292*4882a593Smuzhiyun #undef DOT11_FTM_ERR_SET_MAX_ERR 5293*4882a593Smuzhiyun 5294*4882a593Smuzhiyun #define DOT11_FTM_ERR_MAX_ERR_OFFSET 0 5295*4882a593Smuzhiyun #define DOT11_FTM_ERR_MAX_ERR_MASK 0xfff7 5296*4882a593Smuzhiyun #define DOT11_FTM_ERR_MAX_ERR_SHIFT 1 5297*4882a593Smuzhiyun #define DOT11_FTM_ERR_MAX_ERR(_err) ((((_err)[1] << 7) | (_err)[0]) >> 1) 5298*4882a593Smuzhiyun #define DOT11_FTM_ERR_SET_MAX_ERR(_err, _val) do {\ 5299*4882a593Smuzhiyun uint16 _val2; \ 5300*4882a593Smuzhiyun _val2 = (((_val) << DOT11_FTM_ERR_MAX_ERR_SHIFT) |\ 5301*4882a593Smuzhiyun ((_err)[DOT11_FTM_ERR_NOT_CONT_OFFSET] & DOT11_FTM_ERR_NOT_CONT_MASK)); \ 5302*4882a593Smuzhiyun (_err)[0] = _val2 & 0xff; \ 5303*4882a593Smuzhiyun (_err)[1] = _val2 >> 8 & 0xff; \ 5304*4882a593Smuzhiyun } while (0) 5305*4882a593Smuzhiyun #endif /* DOT11_FTM_ERR_ROM_COMPAT */ 5306*4882a593Smuzhiyun 5307*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ftm_params { 5308*4882a593Smuzhiyun uint8 id; /* DOT11_MNG_FTM_PARAM_ID 8.4.2.166 11mcd2.6/2014 - revisit */ 5309*4882a593Smuzhiyun uint8 len; 5310*4882a593Smuzhiyun uint8 info[9]; 5311*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5312*4882a593Smuzhiyun 5313*4882a593Smuzhiyun typedef struct dot11_ftm_params dot11_ftm_params_t; 5314*4882a593Smuzhiyun #define DOT11_FTM_PARAMS_IE_LEN (sizeof(dot11_ftm_params_t) - 2) 5315*4882a593Smuzhiyun 5316*4882a593Smuzhiyun /* common part for both TB and NTB */ 5317*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ftm_ranging_params { 5318*4882a593Smuzhiyun uint8 id; /* 255 */ 5319*4882a593Smuzhiyun uint8 len; 5320*4882a593Smuzhiyun uint8 ext_id; /* DOT11_MNG_FTM_RANGING_EXT_ID */ 5321*4882a593Smuzhiyun uint8 info[6]; 5322*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5323*4882a593Smuzhiyun typedef struct dot11_ftm_ranging_params dot11_ftm_ranging_params_t; 5324*4882a593Smuzhiyun #define DOT11_FTM_CMN_RANGING_PARAMS_IE_LEN (sizeof(dot11_ftm_ranging_params_t) - TLV_EXT_HDR_LEN) 5325*4882a593Smuzhiyun 5326*4882a593Smuzhiyun /* FTM NTB specific */ 5327*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ftm_ntb_params { 5328*4882a593Smuzhiyun uint8 id; /* DOT11_FTM_NTB_SUB_ELT_ID */ 5329*4882a593Smuzhiyun uint8 len; 5330*4882a593Smuzhiyun uint8 info[6]; 5331*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5332*4882a593Smuzhiyun typedef struct dot11_ftm_ntb_params dot11_ftm_ntb_params_t; 5333*4882a593Smuzhiyun 5334*4882a593Smuzhiyun #define DOT11_FTM_NTB_PARAMS_SUB_IE_LEN (sizeof(dot11_ftm_ntb_params_t)) 5335*4882a593Smuzhiyun #define DOT11_FTM_NTB_PARAMS_IE_LEN DOT11_FTM_CMN_RANGING_PARAMS_IE_LEN + \ 5336*4882a593Smuzhiyun DOT11_FTM_NTB_PARAMS_SUB_IE_LEN 5337*4882a593Smuzhiyun 5338*4882a593Smuzhiyun /* FTM TB specific */ 5339*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ftm_tb_params { 5340*4882a593Smuzhiyun uint8 id; /* DOT11_FTM_TB_SUB_ELT_ID */ 5341*4882a593Smuzhiyun uint8 len; 5342*4882a593Smuzhiyun uint8 info[1]; /* variable length, minimum 1 */ 5343*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5344*4882a593Smuzhiyun 5345*4882a593Smuzhiyun typedef struct dot11_ftm_tb_params dot11_ftm_tb_params_t; 5346*4882a593Smuzhiyun #define DOT11_FTM_TB_PARAMS_IE_LEN sizeof(dot11_ftm_tb_params_t) 5347*4882a593Smuzhiyun 5348*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ftm_sec_ltf_params { 5349*4882a593Smuzhiyun uint8 id; /* 255 */ 5350*4882a593Smuzhiyun uint8 len; 5351*4882a593Smuzhiyun uint8 ext_id; /* DOT11_MNG_FTM_SECURE_LTF_EXT_ID */ 5352*4882a593Smuzhiyun uint8 info[11]; 5353*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5354*4882a593Smuzhiyun typedef struct dot11_ftm_sec_ltf_params dot11_ftm_sec_ltf_params_t; 5355*4882a593Smuzhiyun #define DOT11_FTM_SEC_LTF_PARAMS_IE_LEN (sizeof(dot11_ftm_sec_ltf_params_t) - 3) 5356*4882a593Smuzhiyun 5357*4882a593Smuzhiyun #define FTM_PARAMS_FIELD(_p, _off, _mask, _shift) (((_p)->info[(_off)] & (_mask)) >> (_shift)) 5358*4882a593Smuzhiyun #define FTM_PARAMS_SET_FIELD(_p, _off, _mask, _shift, _val) do {\ 5359*4882a593Smuzhiyun uint8 _ptmp = (_p)->info[_off] & ~(_mask); \ 5360*4882a593Smuzhiyun (_p)->info[(_off)] = _ptmp | (((_val) << (_shift)) & (_mask)); \ 5361*4882a593Smuzhiyun } while (0) 5362*4882a593Smuzhiyun 5363*4882a593Smuzhiyun #define FTM_PARAMS_STATUS_OFFSET 0 5364*4882a593Smuzhiyun #define FTM_PARAMS_STATUS_MASK 0x03 5365*4882a593Smuzhiyun #define FTM_PARAMS_STATUS_SHIFT 0 5366*4882a593Smuzhiyun #define FTM_PARAMS_STATUS(_p) FTM_PARAMS_FIELD(_p, FTM_PARAMS_STATUS_OFFSET, \ 5367*4882a593Smuzhiyun FTM_PARAMS_STATUS_MASK, FTM_PARAMS_STATUS_SHIFT) 5368*4882a593Smuzhiyun #define FTM_PARAMS_SET_STATUS(_p, _status) FTM_PARAMS_SET_FIELD(_p, \ 5369*4882a593Smuzhiyun FTM_PARAMS_STATUS_OFFSET, FTM_PARAMS_STATUS_MASK, FTM_PARAMS_STATUS_SHIFT, _status) 5370*4882a593Smuzhiyun 5371*4882a593Smuzhiyun #define FTM_PARAMS_VALUE_OFFSET 0 5372*4882a593Smuzhiyun #define FTM_PARAMS_VALUE_MASK 0x7c 5373*4882a593Smuzhiyun #define FTM_PARAMS_VALUE_SHIFT 2 5374*4882a593Smuzhiyun #define FTM_PARAMS_VALUE(_p) FTM_PARAMS_FIELD(_p, FTM_PARAMS_VALUE_OFFSET, \ 5375*4882a593Smuzhiyun FTM_PARAMS_VALUE_MASK, FTM_PARAMS_VALUE_SHIFT) 5376*4882a593Smuzhiyun #define FTM_PARAMS_SET_VALUE(_p, _value) FTM_PARAMS_SET_FIELD(_p, \ 5377*4882a593Smuzhiyun FTM_PARAMS_VALUE_OFFSET, FTM_PARAMS_VALUE_MASK, FTM_PARAMS_VALUE_SHIFT, _value) 5378*4882a593Smuzhiyun #define FTM_PARAMS_MAX_VALUE 32 5379*4882a593Smuzhiyun 5380*4882a593Smuzhiyun #define FTM_PARAMS_NBURSTEXP_OFFSET 1 5381*4882a593Smuzhiyun #define FTM_PARAMS_NBURSTEXP_MASK 0x0f 5382*4882a593Smuzhiyun #define FTM_PARAMS_NBURSTEXP_SHIFT 0 5383*4882a593Smuzhiyun #define FTM_PARAMS_NBURSTEXP(_p) FTM_PARAMS_FIELD(_p, FTM_PARAMS_NBURSTEXP_OFFSET, \ 5384*4882a593Smuzhiyun FTM_PARAMS_NBURSTEXP_MASK, FTM_PARAMS_NBURSTEXP_SHIFT) 5385*4882a593Smuzhiyun #define FTM_PARAMS_SET_NBURSTEXP(_p, _bexp) FTM_PARAMS_SET_FIELD(_p, \ 5386*4882a593Smuzhiyun FTM_PARAMS_NBURSTEXP_OFFSET, FTM_PARAMS_NBURSTEXP_MASK, FTM_PARAMS_NBURSTEXP_SHIFT, \ 5387*4882a593Smuzhiyun _bexp) 5388*4882a593Smuzhiyun 5389*4882a593Smuzhiyun #define FTM_PARAMS_NBURST(_p) (1 << FTM_PARAMS_NBURSTEXP(_p)) 5390*4882a593Smuzhiyun 5391*4882a593Smuzhiyun enum { 5392*4882a593Smuzhiyun FTM_PARAMS_NBURSTEXP_NOPREF = 15 5393*4882a593Smuzhiyun }; 5394*4882a593Smuzhiyun 5395*4882a593Smuzhiyun enum { 5396*4882a593Smuzhiyun FTM_PARAMS_BURSTTMO_NOPREF = 15 5397*4882a593Smuzhiyun }; 5398*4882a593Smuzhiyun 5399*4882a593Smuzhiyun #define FTM_PARAMS_BURSTTMO_OFFSET 1 5400*4882a593Smuzhiyun #define FTM_PARAMS_BURSTTMO_MASK 0xf0 5401*4882a593Smuzhiyun #define FTM_PARAMS_BURSTTMO_SHIFT 4 5402*4882a593Smuzhiyun #define FTM_PARAMS_BURSTTMO(_p) FTM_PARAMS_FIELD(_p, FTM_PARAMS_BURSTTMO_OFFSET, \ 5403*4882a593Smuzhiyun FTM_PARAMS_BURSTTMO_MASK, FTM_PARAMS_BURSTTMO_SHIFT) 5404*4882a593Smuzhiyun /* set timeout in params using _tmo where timeout = 2^(_tmo) * 250us */ 5405*4882a593Smuzhiyun #define FTM_PARAMS_SET_BURSTTMO(_p, _tmo) FTM_PARAMS_SET_FIELD(_p, \ 5406*4882a593Smuzhiyun FTM_PARAMS_BURSTTMO_OFFSET, FTM_PARAMS_BURSTTMO_MASK, FTM_PARAMS_BURSTTMO_SHIFT, (_tmo)+2) 5407*4882a593Smuzhiyun 5408*4882a593Smuzhiyun #define FTM_PARAMS_BURSTTMO_USEC(_val) ((1 << ((_val)-2)) * 250) 5409*4882a593Smuzhiyun #define FTM_PARAMS_BURSTTMO_VALID(_val) ((((_val) < 12 && (_val) > 1)) || \ 5410*4882a593Smuzhiyun (_val) == FTM_PARAMS_BURSTTMO_NOPREF) 5411*4882a593Smuzhiyun #define FTM_PARAMS_BURSTTMO_MAX_MSEC 128 /* 2^9 * 250us */ 5412*4882a593Smuzhiyun #define FTM_PARAMS_BURSTTMO_MAX_USEC 128000 /* 2^9 * 250us */ 5413*4882a593Smuzhiyun 5414*4882a593Smuzhiyun #define FTM_PARAMS_MINDELTA_OFFSET 2 5415*4882a593Smuzhiyun #define FTM_PARAMS_MINDELTA_USEC(_p) ((_p)->info[FTM_PARAMS_MINDELTA_OFFSET] * 100) 5416*4882a593Smuzhiyun #define FTM_PARAMS_SET_MINDELTA_USEC(_p, _delta) do { \ 5417*4882a593Smuzhiyun (_p)->info[FTM_PARAMS_MINDELTA_OFFSET] = (_delta) / 100; \ 5418*4882a593Smuzhiyun } while (0) 5419*4882a593Smuzhiyun 5420*4882a593Smuzhiyun enum { 5421*4882a593Smuzhiyun FTM_PARAMS_MINDELTA_NOPREF = 0 5422*4882a593Smuzhiyun }; 5423*4882a593Smuzhiyun 5424*4882a593Smuzhiyun #define FTM_PARAMS_PARTIAL_TSF(_p) ((_p)->info[4] << 8 | (_p)->info[3]) 5425*4882a593Smuzhiyun #define FTM_PARAMS_SET_PARTIAL_TSF(_p, _partial_tsf) do { \ 5426*4882a593Smuzhiyun (_p)->info[3] = (_partial_tsf) & 0xff; \ 5427*4882a593Smuzhiyun (_p)->info[4] = ((_partial_tsf) >> 8) & 0xff; \ 5428*4882a593Smuzhiyun } while (0) 5429*4882a593Smuzhiyun 5430*4882a593Smuzhiyun #define FTM_PARAMS_PARTIAL_TSF_MASK 0x0000000003fffc00ULL 5431*4882a593Smuzhiyun #define FTM_PARAMS_PARTIAL_TSF_SHIFT 10 5432*4882a593Smuzhiyun #define FTM_PARAMS_PARTIAL_TSF_BIT_LEN 16 5433*4882a593Smuzhiyun #define FTM_PARAMS_PARTIAL_TSF_MAX 0xffff 5434*4882a593Smuzhiyun 5435*4882a593Smuzhiyun /* FTM can indicate upto 62k TUs forward and 1k TU backward */ 5436*4882a593Smuzhiyun #define FTM_PARAMS_TSF_FW_HI (63487 << 10) /* in micro sec */ 5437*4882a593Smuzhiyun #define FTM_PARAMS_TSF_BW_LOW (64512 << 10) /* in micro sec */ 5438*4882a593Smuzhiyun #define FTM_PARAMS_TSF_BW_HI (65535 << 10) /* in micro sec */ 5439*4882a593Smuzhiyun #define FTM_PARAMS_TSF_FW_MAX FTM_PARAMS_TSF_FW_HI 5440*4882a593Smuzhiyun #define FTM_PARAMS_TSF_BW_MAX (FTM_PARAMS_TSF_BW_HI - FTM_PARAMS_TSF_BW_LOW) 5441*4882a593Smuzhiyun 5442*4882a593Smuzhiyun #define FTM_PARAMS_PTSFNOPREF_OFFSET 5 5443*4882a593Smuzhiyun #define FTM_PARAMS_PTSFNOPREF_MASK 0x1 5444*4882a593Smuzhiyun #define FTM_PARAMS_PTSFNOPREF_SHIFT 0 5445*4882a593Smuzhiyun #define FTM_PARAMS_PTSFNOPREF(_p) FTM_PARAMS_FIELD(_p, FTM_PARAMS_PTSFNOPREF_OFFSET, \ 5446*4882a593Smuzhiyun FTM_PARAMS_PTSFNOPREF_MASK, FTM_PARAMS_PTSFNOPREF_SHIFT) 5447*4882a593Smuzhiyun #define FTM_PARAMS_SET_PTSFNOPREF(_p, _nopref) FTM_PARAMS_SET_FIELD(_p, \ 5448*4882a593Smuzhiyun FTM_PARAMS_PTSFNOPREF_OFFSET, FTM_PARAMS_PTSFNOPREF_MASK, \ 5449*4882a593Smuzhiyun FTM_PARAMS_PTSFNOPREF_SHIFT, _nopref) 5450*4882a593Smuzhiyun 5451*4882a593Smuzhiyun #define FTM_PARAMS_ASAP_OFFSET 5 5452*4882a593Smuzhiyun #define FTM_PARAMS_ASAP_MASK 0x4 5453*4882a593Smuzhiyun #define FTM_PARAMS_ASAP_SHIFT 2 5454*4882a593Smuzhiyun #define FTM_PARAMS_ASAP(_p) FTM_PARAMS_FIELD(_p, FTM_PARAMS_ASAP_OFFSET, \ 5455*4882a593Smuzhiyun FTM_PARAMS_ASAP_MASK, FTM_PARAMS_ASAP_SHIFT) 5456*4882a593Smuzhiyun #define FTM_PARAMS_SET_ASAP(_p, _asap) FTM_PARAMS_SET_FIELD(_p, \ 5457*4882a593Smuzhiyun FTM_PARAMS_ASAP_OFFSET, FTM_PARAMS_ASAP_MASK, FTM_PARAMS_ASAP_SHIFT, _asap) 5458*4882a593Smuzhiyun 5459*4882a593Smuzhiyun /* FTM1 - AKA ASAP Capable */ 5460*4882a593Smuzhiyun #define FTM_PARAMS_FTM1_OFFSET 5 5461*4882a593Smuzhiyun #define FTM_PARAMS_FTM1_MASK 0x02 5462*4882a593Smuzhiyun #define FTM_PARAMS_FTM1_SHIFT 1 5463*4882a593Smuzhiyun #define FTM_PARAMS_FTM1(_p) FTM_PARAMS_FIELD(_p, FTM_PARAMS_FTM1_OFFSET, \ 5464*4882a593Smuzhiyun FTM_PARAMS_FTM1_MASK, FTM_PARAMS_FTM1_SHIFT) 5465*4882a593Smuzhiyun #define FTM_PARAMS_SET_FTM1(_p, _ftm1) FTM_PARAMS_SET_FIELD(_p, \ 5466*4882a593Smuzhiyun FTM_PARAMS_FTM1_OFFSET, FTM_PARAMS_FTM1_MASK, FTM_PARAMS_FTM1_SHIFT, _ftm1) 5467*4882a593Smuzhiyun 5468*4882a593Smuzhiyun #define FTM_PARAMS_FTMS_PER_BURST_OFFSET 5 5469*4882a593Smuzhiyun #define FTM_PARAMS_FTMS_PER_BURST_MASK 0xf8 5470*4882a593Smuzhiyun #define FTM_PARAMS_FTMS_PER_BURST_SHIFT 3 5471*4882a593Smuzhiyun #define FTM_PARAMS_FTMS_PER_BURST(_p) FTM_PARAMS_FIELD(_p, FTM_PARAMS_FTMS_PER_BURST_OFFSET, \ 5472*4882a593Smuzhiyun FTM_PARAMS_FTMS_PER_BURST_MASK, FTM_PARAMS_FTMS_PER_BURST_SHIFT) 5473*4882a593Smuzhiyun #define FTM_PARAMS_SET_FTMS_PER_BURST(_p, _nftms) FTM_PARAMS_SET_FIELD(_p, \ 5474*4882a593Smuzhiyun FTM_PARAMS_FTMS_PER_BURST_OFFSET, FTM_PARAMS_FTMS_PER_BURST_MASK, \ 5475*4882a593Smuzhiyun FTM_PARAMS_FTMS_PER_BURST_SHIFT, _nftms) 5476*4882a593Smuzhiyun 5477*4882a593Smuzhiyun enum { 5478*4882a593Smuzhiyun FTM_PARAMS_FTMS_PER_BURST_NOPREF = 0 5479*4882a593Smuzhiyun }; 5480*4882a593Smuzhiyun 5481*4882a593Smuzhiyun #define FTM_PARAMS_CHAN_INFO_OFFSET 6 5482*4882a593Smuzhiyun #define FTM_PARAMS_CHAN_INFO_MASK 0xfc 5483*4882a593Smuzhiyun #define FTM_PARAMS_CHAN_INFO_SHIFT 2 5484*4882a593Smuzhiyun #define FTM_PARAMS_CHAN_INFO(_p) FTM_PARAMS_FIELD(_p, FTM_PARAMS_CHAN_INFO_OFFSET, \ 5485*4882a593Smuzhiyun FTM_PARAMS_CHAN_INFO_MASK, FTM_PARAMS_CHAN_INFO_SHIFT) 5486*4882a593Smuzhiyun #define FTM_PARAMS_SET_CHAN_INFO(_p, _ci) FTM_PARAMS_SET_FIELD(_p, \ 5487*4882a593Smuzhiyun FTM_PARAMS_CHAN_INFO_OFFSET, FTM_PARAMS_CHAN_INFO_MASK, FTM_PARAMS_CHAN_INFO_SHIFT, _ci) 5488*4882a593Smuzhiyun 5489*4882a593Smuzhiyun /* burst period - units of 100ms */ 5490*4882a593Smuzhiyun #define FTM_PARAMS_BURST_PERIOD(_p) (((_p)->info[8] << 8) | (_p)->info[7]) 5491*4882a593Smuzhiyun #define FTM_PARAMS_SET_BURST_PERIOD(_p, _bp) do {\ 5492*4882a593Smuzhiyun (_p)->info[7] = (_bp) & 0xff; \ 5493*4882a593Smuzhiyun (_p)->info[8] = ((_bp) >> 8) & 0xff; \ 5494*4882a593Smuzhiyun } while (0) 5495*4882a593Smuzhiyun 5496*4882a593Smuzhiyun #define FTM_PARAMS_BURST_PERIOD_MS(_p) (FTM_PARAMS_BURST_PERIOD(_p) * 100) 5497*4882a593Smuzhiyun 5498*4882a593Smuzhiyun enum { 5499*4882a593Smuzhiyun FTM_PARAMS_BURST_PERIOD_NOPREF = 0 5500*4882a593Smuzhiyun }; 5501*4882a593Smuzhiyun 5502*4882a593Smuzhiyun /* FTM status values - last updated from 11mcD4.0 */ 5503*4882a593Smuzhiyun enum { 5504*4882a593Smuzhiyun FTM_PARAMS_STATUS_RESERVED = 0, 5505*4882a593Smuzhiyun FTM_PARAMS_STATUS_SUCCESSFUL = 1, 5506*4882a593Smuzhiyun FTM_PARAMS_STATUS_INCAPABLE = 2, 5507*4882a593Smuzhiyun FTM_PARAMS_STATUS_FAILED = 3, 5508*4882a593Smuzhiyun /* Below are obsolte */ 5509*4882a593Smuzhiyun FTM_PARAMS_STATUS_OVERRIDDEN = 4, 5510*4882a593Smuzhiyun FTM_PARAMS_STATUS_ASAP_INCAPABLE = 5, 5511*4882a593Smuzhiyun FTM_PARAMS_STATUS_ASAP_FAILED = 6, 5512*4882a593Smuzhiyun /* rest are reserved */ 5513*4882a593Smuzhiyun }; 5514*4882a593Smuzhiyun 5515*4882a593Smuzhiyun enum { 5516*4882a593Smuzhiyun FTM_PARAMS_CHAN_INFO_NO_PREF = 0, 5517*4882a593Smuzhiyun FTM_PARAMS_CHAN_INFO_RESERVE1 = 1, 5518*4882a593Smuzhiyun FTM_PARAMS_CHAN_INFO_RESERVE2 = 2, 5519*4882a593Smuzhiyun FTM_PARAMS_CHAN_INFO_RESERVE3 = 3, 5520*4882a593Smuzhiyun FTM_PARAMS_CHAN_INFO_NON_HT_5 = 4, 5521*4882a593Smuzhiyun FTM_PARAMS_CHAN_INFO_RESERVE5 = 5, 5522*4882a593Smuzhiyun FTM_PARAMS_CHAN_INFO_NON_HT_10 = 6, 5523*4882a593Smuzhiyun FTM_PARAMS_CHAN_INFO_RESERVE7 = 7, 5524*4882a593Smuzhiyun FTM_PARAMS_CHAN_INFO_NON_HT_20 = 8, /* excludes 2.4G, and High rate DSSS */ 5525*4882a593Smuzhiyun FTM_PARAMS_CHAN_INFO_HT_MF_20 = 9, 5526*4882a593Smuzhiyun FTM_PARAMS_CHAN_INFO_VHT_20 = 10, 5527*4882a593Smuzhiyun FTM_PARAMS_CHAN_INFO_HT_MF_40 = 11, 5528*4882a593Smuzhiyun FTM_PARAMS_CHAN_INFO_VHT_40 = 12, 5529*4882a593Smuzhiyun FTM_PARAMS_CHAN_INFO_VHT_80 = 13, 5530*4882a593Smuzhiyun FTM_PARAMS_CHAN_INFO_VHT_80_80 = 14, 5531*4882a593Smuzhiyun FTM_PARAMS_CHAN_INFO_VHT_160_2_RFLOS = 15, 5532*4882a593Smuzhiyun FTM_PARAMS_CHAN_INFO_VHT_160 = 16, 5533*4882a593Smuzhiyun /* Reserved from 17 - 30 */ 5534*4882a593Smuzhiyun FTM_PARAMS_CHAN_INFO_DMG_2160 = 31, 5535*4882a593Smuzhiyun /* Reserved from 32 - 63 */ 5536*4882a593Smuzhiyun FTM_PARAMS_CHAN_INFO_MAX = 63 5537*4882a593Smuzhiyun }; 5538*4882a593Smuzhiyun 5539*4882a593Smuzhiyun /* tag_ID/length/value_buffer tuple */ 5540*4882a593Smuzhiyun typedef BWL_PRE_PACKED_STRUCT struct { 5541*4882a593Smuzhiyun uint8 id; 5542*4882a593Smuzhiyun uint8 len; 5543*4882a593Smuzhiyun uint8 data[1]; 5544*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT ftm_vs_tlv_t; 5545*4882a593Smuzhiyun 5546*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ftm_vs_ie { 5547*4882a593Smuzhiyun uint8 id; /* DOT11_MNG_VS_ID */ 5548*4882a593Smuzhiyun uint8 len; /* length following */ 5549*4882a593Smuzhiyun uint8 oui[3]; /* BRCM_PROP_OUI (or Customer) */ 5550*4882a593Smuzhiyun uint8 sub_type; /* BRCM_FTM_IE_TYPE (or Customer) */ 5551*4882a593Smuzhiyun uint8 version; 5552*4882a593Smuzhiyun ftm_vs_tlv_t tlvs[1]; 5553*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5554*4882a593Smuzhiyun typedef struct dot11_ftm_vs_ie dot11_ftm_vs_ie_t; 5555*4882a593Smuzhiyun 5556*4882a593Smuzhiyun /* same as payload of dot11_ftm_vs_ie. 5557*4882a593Smuzhiyun * This definition helps in having struct access 5558*4882a593Smuzhiyun * of pay load while building FTM VS IE from other modules(NAN) 5559*4882a593Smuzhiyun */ 5560*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ftm_vs_ie_pyld { 5561*4882a593Smuzhiyun uint8 sub_type; /* BRCM_FTM_IE_TYPE (or Customer) */ 5562*4882a593Smuzhiyun uint8 version; 5563*4882a593Smuzhiyun ftm_vs_tlv_t tlvs[1]; 5564*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5565*4882a593Smuzhiyun typedef struct dot11_ftm_vs_ie_pyld dot11_ftm_vs_ie_pyld_t; 5566*4882a593Smuzhiyun 5567*4882a593Smuzhiyun /* ftm vs api version */ 5568*4882a593Smuzhiyun #define BCM_FTM_VS_PARAMS_VERSION 0x01 5569*4882a593Smuzhiyun 5570*4882a593Smuzhiyun /* ftm vendor specific information tlv types */ 5571*4882a593Smuzhiyun enum { 5572*4882a593Smuzhiyun FTM_VS_TLV_NONE = 0, 5573*4882a593Smuzhiyun FTM_VS_TLV_REQ_PARAMS = 1, /* additional request params (in FTM_REQ) */ 5574*4882a593Smuzhiyun FTM_VS_TLV_MEAS_INFO = 2, /* measurement information (in FTM_MEAS) */ 5575*4882a593Smuzhiyun FTM_VS_TLV_SEC_PARAMS = 3, /* security parameters (in either) */ 5576*4882a593Smuzhiyun FTM_VS_TLV_SEQ_PARAMS = 4, /* toast parameters (FTM_REQ, BRCM proprietary) */ 5577*4882a593Smuzhiyun FTM_VS_TLV_MF_BUF = 5, /* multi frame buffer - may span ftm vs ie's */ 5578*4882a593Smuzhiyun FTM_VS_TLV_TIMING_PARAMS = 6, /* timing adjustments */ 5579*4882a593Smuzhiyun FTM_VS_TLV_MF_STATS_BUF = 7 /* multi frame statistics buffer */ 5580*4882a593Smuzhiyun /* add additional types above */ 5581*4882a593Smuzhiyun }; 5582*4882a593Smuzhiyun 5583*4882a593Smuzhiyun /* the following definitions are *DEPRECATED* and moved to implementation files. They 5584*4882a593Smuzhiyun * are retained here because previous (May 2016) some branches use them 5585*4882a593Smuzhiyun */ 5586*4882a593Smuzhiyun #define FTM_TPK_LEN 16u 5587*4882a593Smuzhiyun #define FTM_RI_RR_BUF_LEN 32u 5588*4882a593Smuzhiyun #define FTM_TPK_RI_RR_LEN 13 5589*4882a593Smuzhiyun #define FTM_TPK_RI_RR_LEN_SECURE_2_0 28 5590*4882a593Smuzhiyun #define FTM_TPK_RI_PHY_LEN 7u 5591*4882a593Smuzhiyun #define FTM_TPK_RR_PHY_LEN 7u 5592*4882a593Smuzhiyun #define FTM_TPK_DATA_BUFFER_LEN 88u 5593*4882a593Smuzhiyun #define FTM_TPK_LEN_SECURE_2_0 64u 5594*4882a593Smuzhiyun #define FTM_TPK_RI_PHY_LEN_SECURE_2_0 14u 5595*4882a593Smuzhiyun #define FTM_TPK_RR_PHY_LEN_SECURE_2_0 14u 5596*4882a593Smuzhiyun 5597*4882a593Smuzhiyun #define FTM_RI_RR_BUF_LEN_20MHZ 32u 5598*4882a593Smuzhiyun #define FTM_RI_RR_BUF_LEN_80MHZ 64u 5599*4882a593Smuzhiyun 5600*4882a593Smuzhiyun #define FTM_RI_RR_BUF_LEN_FROM_CHANSPEC(chanspec) \ 5601*4882a593Smuzhiyun (CHSPEC_IS20((chanspec)) ? \ 5602*4882a593Smuzhiyun FTM_RI_RR_BUF_LEN_20MHZ : FTM_RI_RR_BUF_LEN_80MHZ) 5603*4882a593Smuzhiyun 5604*4882a593Smuzhiyun #define FTM_TPK_RI_RR_LEN_SECURE_2_0_20MHZ 28u 5605*4882a593Smuzhiyun #define FTM_TPK_RI_RR_LEN_SECURE_2_0_80MHZ 62u 5606*4882a593Smuzhiyun #define FTM_TPK_RI_RR_LEN_SECURE_2_0_2G FTM_TPK_RI_RR_LEN_SECURE_2_0 5607*4882a593Smuzhiyun #define FTM_TPK_RI_RR_LEN_SECURE_2_0_5G FTM_TPK_RI_RR_LEN_SECURE_2_0_80MHZ 5608*4882a593Smuzhiyun 5609*4882a593Smuzhiyun #define FTM_TPK_RI_RR_LEN_FROM_CHANSPEC(chanspec) \ 5610*4882a593Smuzhiyun (CHSPEC_IS20((chanspec)) ? FTM_TPK_RI_RR_LEN_SECURE_2_0_20MHZ : \ 5611*4882a593Smuzhiyun FTM_TPK_RI_RR_LEN_SECURE_2_0_80MHZ) 5612*4882a593Smuzhiyun 5613*4882a593Smuzhiyun #define FTM_TPK_RI_PHY_LEN_SECURE_2_0_20MHZ 14u 5614*4882a593Smuzhiyun #define FTM_TPK_RI_PHY_LEN_SECURE_2_0_80MHZ 31u 5615*4882a593Smuzhiyun #define FTM_TPK_RR_PHY_LEN_SECURE_2_0_80MHZ 31u 5616*4882a593Smuzhiyun 5617*4882a593Smuzhiyun #define FTM_TPK_RI_PHY_LEN_FROM_CHANSPEC(chanspec) \ 5618*4882a593Smuzhiyun (CHSPEC_IS20((chanspec)) ? FTM_TPK_RI_PHY_LEN_SECURE_2_0_20MHZ : \ 5619*4882a593Smuzhiyun FTM_TPK_RI_PHY_LEN_SECURE_2_0_80MHZ) 5620*4882a593Smuzhiyun 5621*4882a593Smuzhiyun #define FTM_TPK_RR_PHY_LEN_SECURE_2_0_20MHZ 14u 5622*4882a593Smuzhiyun 5623*4882a593Smuzhiyun #define FTM_TPK_RR_PHY_LEN_FROM_CHANSPEC(chanspec) \ 5624*4882a593Smuzhiyun (CHSPEC_IS20((chanspec)) ? FTM_TPK_RR_PHY_LEN_SECURE_2_0_20MHZ : \ 5625*4882a593Smuzhiyun FTM_TPK_RR_PHY_LEN_SECURE_2_0_80MHZ) 5626*4882a593Smuzhiyun 5627*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ftm_vs_params { 5628*4882a593Smuzhiyun uint8 id; /* DOT11_MNG_VS_ID */ 5629*4882a593Smuzhiyun uint8 len; 5630*4882a593Smuzhiyun uint8 oui[3]; /* Proprietary OUI, BRCM_PROP_OUI */ 5631*4882a593Smuzhiyun uint8 bcm_vs_id; 5632*4882a593Smuzhiyun ftm_vs_tlv_t ftm_tpk_ri_rr[1]; /* ftm_TPK_ri_rr place holder */ 5633*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5634*4882a593Smuzhiyun typedef struct dot11_ftm_vs_params dot11_ftm_vs_tpk_ri_rr_params_t; 5635*4882a593Smuzhiyun #define DOT11_FTM_VS_LEN (sizeof(dot11_ftm_vs_tpk_ri_rr_params_t) - TLV_HDR_LEN) 5636*4882a593Smuzhiyun /* end *DEPRECATED* ftm definitions */ 5637*4882a593Smuzhiyun 5638*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_ftm_sync_info { 5639*4882a593Smuzhiyun uint8 id; /* Extended - 255 11mc D4.3 */ 5640*4882a593Smuzhiyun uint8 len; 5641*4882a593Smuzhiyun uint8 id_ext; 5642*4882a593Smuzhiyun uint8 tsf_sync_info[4]; 5643*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5644*4882a593Smuzhiyun typedef struct dot11_ftm_sync_info dot11_ftm_sync_info_t; 5645*4882a593Smuzhiyun 5646*4882a593Smuzhiyun /* ftm tsf sync info ie len - includes id ext */ 5647*4882a593Smuzhiyun #define DOT11_FTM_SYNC_INFO_IE_LEN (sizeof(dot11_ftm_sync_info_t) - TLV_HDR_LEN) 5648*4882a593Smuzhiyun 5649*4882a593Smuzhiyun #define DOT11_FTM_IS_SYNC_INFO_IE(_ie) (\ 5650*4882a593Smuzhiyun DOT11_MNG_IE_ID_EXT_MATCH(_ie, DOT11_MNG_FTM_SYNC_INFO) && \ 5651*4882a593Smuzhiyun (_ie)->len == DOT11_FTM_SYNC_INFO_IE_LEN) 5652*4882a593Smuzhiyun 5653*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct dot11_dh_param_ie { 5654*4882a593Smuzhiyun uint8 id; /* OWE */ 5655*4882a593Smuzhiyun uint8 len; 5656*4882a593Smuzhiyun uint8 ext_id; /* EXT_MNG_OWE_DH_PARAM_ID */ 5657*4882a593Smuzhiyun uint16 group; 5658*4882a593Smuzhiyun uint8 pub_key[0]; 5659*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5660*4882a593Smuzhiyun typedef struct dot11_dh_param_ie dot11_dh_param_ie_t; 5661*4882a593Smuzhiyun 5662*4882a593Smuzhiyun #define DOT11_DH_EXTID_OFFSET (OFFSETOF(dot11_dh_param_ie_t, ext_id)) 5663*4882a593Smuzhiyun 5664*4882a593Smuzhiyun #define DOT11_OWE_DH_PARAM_IE(_ie) (\ 5665*4882a593Smuzhiyun DOT11_MNG_IE_ID_EXT_MATCH(_ie, EXT_MNG_OWE_DH_PARAM_ID)) 5666*4882a593Smuzhiyun 5667*4882a593Smuzhiyun #define DOT11_MNG_OWE_IE_ID_EXT_INIT(_ie, _id, _len) do {\ 5668*4882a593Smuzhiyun (_ie)->id = DOT11_MNG_ID_EXT_ID; \ 5669*4882a593Smuzhiyun (_ie)->len = _len; \ 5670*4882a593Smuzhiyun (_ie)->ext_id = _id; \ 5671*4882a593Smuzhiyun } while (0) 5672*4882a593Smuzhiyun 5673*4882a593Smuzhiyun /* 802.11u interworking access network options */ 5674*4882a593Smuzhiyun #define IW_ANT_MASK 0x0f 5675*4882a593Smuzhiyun #define IW_INTERNET_MASK 0x10 5676*4882a593Smuzhiyun #define IW_ASRA_MASK 0x20 5677*4882a593Smuzhiyun #define IW_ESR_MASK 0x40 5678*4882a593Smuzhiyun #define IW_UESA_MASK 0x80 5679*4882a593Smuzhiyun 5680*4882a593Smuzhiyun /* 802.11u interworking access network type */ 5681*4882a593Smuzhiyun #define IW_ANT_PRIVATE_NETWORK 0 5682*4882a593Smuzhiyun #define IW_ANT_PRIVATE_NETWORK_WITH_GUEST 1 5683*4882a593Smuzhiyun #define IW_ANT_CHARGEABLE_PUBLIC_NETWORK 2 5684*4882a593Smuzhiyun #define IW_ANT_FREE_PUBLIC_NETWORK 3 5685*4882a593Smuzhiyun #define IW_ANT_PERSONAL_DEVICE_NETWORK 4 5686*4882a593Smuzhiyun #define IW_ANT_EMERGENCY_SERVICES_NETWORK 5 5687*4882a593Smuzhiyun #define IW_ANT_TEST_NETWORK 14 5688*4882a593Smuzhiyun #define IW_ANT_WILDCARD_NETWORK 15 5689*4882a593Smuzhiyun 5690*4882a593Smuzhiyun #define IW_ANT_LEN 1 5691*4882a593Smuzhiyun #define IW_VENUE_LEN 2 5692*4882a593Smuzhiyun #define IW_HESSID_LEN 6 5693*4882a593Smuzhiyun #define IW_HESSID_OFF (IW_ANT_LEN + IW_VENUE_LEN) 5694*4882a593Smuzhiyun #define IW_MAX_LEN (IW_ANT_LEN + IW_VENUE_LEN + IW_HESSID_LEN) 5695*4882a593Smuzhiyun 5696*4882a593Smuzhiyun /* 802.11u advertisement protocol */ 5697*4882a593Smuzhiyun #define ADVP_ANQP_PROTOCOL_ID 0 5698*4882a593Smuzhiyun #define ADVP_MIH_PROTOCOL_ID 1 5699*4882a593Smuzhiyun 5700*4882a593Smuzhiyun /* 802.11u advertisement protocol masks */ 5701*4882a593Smuzhiyun #define ADVP_QRL_MASK 0x7f 5702*4882a593Smuzhiyun #define ADVP_PAME_BI_MASK 0x80 5703*4882a593Smuzhiyun 5704*4882a593Smuzhiyun /* 802.11u advertisement protocol values */ 5705*4882a593Smuzhiyun #define ADVP_QRL_REQUEST 0x00 5706*4882a593Smuzhiyun #define ADVP_QRL_RESPONSE 0x7f 5707*4882a593Smuzhiyun #define ADVP_PAME_BI_DEPENDENT 0x00 5708*4882a593Smuzhiyun #define ADVP_PAME_BI_INDEPENDENT ADVP_PAME_BI_MASK 5709*4882a593Smuzhiyun 5710*4882a593Smuzhiyun /* 802.11u ANQP information ID */ 5711*4882a593Smuzhiyun #define ANQP_ID_QUERY_LIST 256 5712*4882a593Smuzhiyun #define ANQP_ID_CAPABILITY_LIST 257 5713*4882a593Smuzhiyun #define ANQP_ID_VENUE_NAME_INFO 258 5714*4882a593Smuzhiyun #define ANQP_ID_EMERGENCY_CALL_NUMBER_INFO 259 5715*4882a593Smuzhiyun #define ANQP_ID_NETWORK_AUTHENTICATION_TYPE_INFO 260 5716*4882a593Smuzhiyun #define ANQP_ID_ROAMING_CONSORTIUM_LIST 261 5717*4882a593Smuzhiyun #define ANQP_ID_IP_ADDRESS_TYPE_AVAILABILITY_INFO 262 5718*4882a593Smuzhiyun #define ANQP_ID_NAI_REALM_LIST 263 5719*4882a593Smuzhiyun #define ANQP_ID_G3PP_CELLULAR_NETWORK_INFO 264 5720*4882a593Smuzhiyun #define ANQP_ID_AP_GEOSPATIAL_LOCATION 265 5721*4882a593Smuzhiyun #define ANQP_ID_AP_CIVIC_LOCATION 266 5722*4882a593Smuzhiyun #define ANQP_ID_AP_LOCATION_PUBLIC_ID_URI 267 5723*4882a593Smuzhiyun #define ANQP_ID_DOMAIN_NAME_LIST 268 5724*4882a593Smuzhiyun #define ANQP_ID_EMERGENCY_ALERT_ID_URI 269 5725*4882a593Smuzhiyun #define ANQP_ID_EMERGENCY_NAI 271 5726*4882a593Smuzhiyun #define ANQP_ID_NEIGHBOR_REPORT 272 5727*4882a593Smuzhiyun #define ANQP_ID_VENDOR_SPECIFIC_LIST 56797 5728*4882a593Smuzhiyun 5729*4882a593Smuzhiyun /* 802.11u ANQP ID len */ 5730*4882a593Smuzhiyun #define ANQP_INFORMATION_ID_LEN 2 5731*4882a593Smuzhiyun 5732*4882a593Smuzhiyun /* 802.11u ANQP OUI */ 5733*4882a593Smuzhiyun #define ANQP_OUI_SUBTYPE 9 5734*4882a593Smuzhiyun 5735*4882a593Smuzhiyun /* 802.11u venue name */ 5736*4882a593Smuzhiyun #define VENUE_LANGUAGE_CODE_SIZE 3 5737*4882a593Smuzhiyun #define VENUE_NAME_SIZE 255 5738*4882a593Smuzhiyun 5739*4882a593Smuzhiyun /* 802.11u venue groups */ 5740*4882a593Smuzhiyun #define VENUE_UNSPECIFIED 0 5741*4882a593Smuzhiyun #define VENUE_ASSEMBLY 1 5742*4882a593Smuzhiyun #define VENUE_BUSINESS 2 5743*4882a593Smuzhiyun #define VENUE_EDUCATIONAL 3 5744*4882a593Smuzhiyun #define VENUE_FACTORY 4 5745*4882a593Smuzhiyun #define VENUE_INSTITUTIONAL 5 5746*4882a593Smuzhiyun #define VENUE_MERCANTILE 6 5747*4882a593Smuzhiyun #define VENUE_RESIDENTIAL 7 5748*4882a593Smuzhiyun #define VENUE_STORAGE 8 5749*4882a593Smuzhiyun #define VENUE_UTILITY 9 5750*4882a593Smuzhiyun #define VENUE_VEHICULAR 10 5751*4882a593Smuzhiyun #define VENUE_OUTDOOR 11 5752*4882a593Smuzhiyun 5753*4882a593Smuzhiyun /* 802.11u network authentication type indicator */ 5754*4882a593Smuzhiyun #define NATI_UNSPECIFIED -1 5755*4882a593Smuzhiyun #define NATI_ACCEPTANCE_OF_TERMS_CONDITIONS 0 5756*4882a593Smuzhiyun #define NATI_ONLINE_ENROLLMENT_SUPPORTED 1 5757*4882a593Smuzhiyun #define NATI_HTTP_HTTPS_REDIRECTION 2 5758*4882a593Smuzhiyun #define NATI_DNS_REDIRECTION 3 5759*4882a593Smuzhiyun 5760*4882a593Smuzhiyun /* 802.11u IP address type availability - IPv6 */ 5761*4882a593Smuzhiyun #define IPA_IPV6_SHIFT 0 5762*4882a593Smuzhiyun #define IPA_IPV6_MASK (0x03 << IPA_IPV6_SHIFT) 5763*4882a593Smuzhiyun #define IPA_IPV6_NOT_AVAILABLE 0x00 5764*4882a593Smuzhiyun #define IPA_IPV6_AVAILABLE 0x01 5765*4882a593Smuzhiyun #define IPA_IPV6_UNKNOWN_AVAILABILITY 0x02 5766*4882a593Smuzhiyun 5767*4882a593Smuzhiyun /* 802.11u IP address type availability - IPv4 */ 5768*4882a593Smuzhiyun #define IPA_IPV4_SHIFT 2 5769*4882a593Smuzhiyun #define IPA_IPV4_MASK (0x3f << IPA_IPV4_SHIFT) 5770*4882a593Smuzhiyun #define IPA_IPV4_NOT_AVAILABLE 0x00 5771*4882a593Smuzhiyun #define IPA_IPV4_PUBLIC 0x01 5772*4882a593Smuzhiyun #define IPA_IPV4_PORT_RESTRICT 0x02 5773*4882a593Smuzhiyun #define IPA_IPV4_SINGLE_NAT 0x03 5774*4882a593Smuzhiyun #define IPA_IPV4_DOUBLE_NAT 0x04 5775*4882a593Smuzhiyun #define IPA_IPV4_PORT_RESTRICT_SINGLE_NAT 0x05 5776*4882a593Smuzhiyun #define IPA_IPV4_PORT_RESTRICT_DOUBLE_NAT 0x06 5777*4882a593Smuzhiyun #define IPA_IPV4_UNKNOWN_AVAILABILITY 0x07 5778*4882a593Smuzhiyun 5779*4882a593Smuzhiyun /* 802.11u NAI realm encoding */ 5780*4882a593Smuzhiyun #define REALM_ENCODING_RFC4282 0 5781*4882a593Smuzhiyun #define REALM_ENCODING_UTF8 1 5782*4882a593Smuzhiyun 5783*4882a593Smuzhiyun /* 802.11u IANA EAP method type numbers */ 5784*4882a593Smuzhiyun #define REALM_EAP_TLS 13 5785*4882a593Smuzhiyun #define REALM_EAP_LEAP 17 5786*4882a593Smuzhiyun #define REALM_EAP_SIM 18 5787*4882a593Smuzhiyun #define REALM_EAP_TTLS 21 5788*4882a593Smuzhiyun #define REALM_EAP_AKA 23 5789*4882a593Smuzhiyun #define REALM_EAP_PEAP 25 5790*4882a593Smuzhiyun #define REALM_EAP_FAST 43 5791*4882a593Smuzhiyun #define REALM_EAP_PSK 47 5792*4882a593Smuzhiyun #define REALM_EAP_AKAP 50 5793*4882a593Smuzhiyun #define REALM_EAP_EXPANDED 254 5794*4882a593Smuzhiyun 5795*4882a593Smuzhiyun /* 802.11u authentication ID */ 5796*4882a593Smuzhiyun #define REALM_EXPANDED_EAP 1 5797*4882a593Smuzhiyun #define REALM_NON_EAP_INNER_AUTHENTICATION 2 5798*4882a593Smuzhiyun #define REALM_INNER_AUTHENTICATION_EAP 3 5799*4882a593Smuzhiyun #define REALM_EXPANDED_INNER_EAP 4 5800*4882a593Smuzhiyun #define REALM_CREDENTIAL 5 5801*4882a593Smuzhiyun #define REALM_TUNNELED_EAP_CREDENTIAL 6 5802*4882a593Smuzhiyun #define REALM_VENDOR_SPECIFIC_EAP 221 5803*4882a593Smuzhiyun 5804*4882a593Smuzhiyun /* 802.11u non-EAP inner authentication type */ 5805*4882a593Smuzhiyun #define REALM_RESERVED_AUTH 0 5806*4882a593Smuzhiyun #define REALM_PAP 1 5807*4882a593Smuzhiyun #define REALM_CHAP 2 5808*4882a593Smuzhiyun #define REALM_MSCHAP 3 5809*4882a593Smuzhiyun #define REALM_MSCHAPV2 4 5810*4882a593Smuzhiyun 5811*4882a593Smuzhiyun /* 802.11u credential type */ 5812*4882a593Smuzhiyun #define REALM_SIM 1 5813*4882a593Smuzhiyun #define REALM_USIM 2 5814*4882a593Smuzhiyun #define REALM_NFC 3 5815*4882a593Smuzhiyun #define REALM_HARDWARE_TOKEN 4 5816*4882a593Smuzhiyun #define REALM_SOFTOKEN 5 5817*4882a593Smuzhiyun #define REALM_CERTIFICATE 6 5818*4882a593Smuzhiyun #define REALM_USERNAME_PASSWORD 7 5819*4882a593Smuzhiyun #define REALM_SERVER_SIDE 8 5820*4882a593Smuzhiyun #define REALM_RESERVED_CRED 9 5821*4882a593Smuzhiyun #define REALM_VENDOR_SPECIFIC_CRED 10 5822*4882a593Smuzhiyun 5823*4882a593Smuzhiyun /* 802.11u 3GPP PLMN */ 5824*4882a593Smuzhiyun #define G3PP_GUD_VERSION 0 5825*4882a593Smuzhiyun #define G3PP_PLMN_LIST_IE 0 5826*4882a593Smuzhiyun 5827*4882a593Smuzhiyun /* AP Location Public ID Info encoding */ 5828*4882a593Smuzhiyun #define PUBLIC_ID_URI_FQDN_SE_ID 0 5829*4882a593Smuzhiyun /* URI/FQDN Descriptor field values */ 5830*4882a593Smuzhiyun #define LOCATION_ENCODING_HELD 1 5831*4882a593Smuzhiyun #define LOCATION_ENCODING_SUPL 2 5832*4882a593Smuzhiyun #define URI_FQDN_SIZE 255 5833*4882a593Smuzhiyun 5834*4882a593Smuzhiyun /** hotspot2.0 indication element (vendor specific) */ 5835*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct hs20_ie { 5836*4882a593Smuzhiyun uint8 oui[3]; 5837*4882a593Smuzhiyun uint8 type; 5838*4882a593Smuzhiyun uint8 config; 5839*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5840*4882a593Smuzhiyun typedef struct hs20_ie hs20_ie_t; 5841*4882a593Smuzhiyun #define HS20_IE_LEN 5 /* HS20 IE length */ 5842*4882a593Smuzhiyun 5843*4882a593Smuzhiyun /* Short SSID list Extended Capabilities element */ 5844*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct short_ssid_list_ie { 5845*4882a593Smuzhiyun uint8 id; 5846*4882a593Smuzhiyun uint8 len; 5847*4882a593Smuzhiyun uint8 id_ext; 5848*4882a593Smuzhiyun uint8 data[1]; /* Capabilities Information */ 5849*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5850*4882a593Smuzhiyun 5851*4882a593Smuzhiyun typedef struct short_ssid_list_ie short_ssid_list_ie_t; 5852*4882a593Smuzhiyun #define SHORT_SSID_LIST_IE_FIXED_LEN 3 /* SHORT SSID LIST IE LENGTH */ 5853*4882a593Smuzhiyun 5854*4882a593Smuzhiyun /** IEEE 802.11 Annex E */ 5855*4882a593Smuzhiyun typedef enum { 5856*4882a593Smuzhiyun DOT11_2GHZ_20MHZ_CLASS_12 = 81, /* Ch 1-11 */ 5857*4882a593Smuzhiyun DOT11_5GHZ_20MHZ_CLASS_1 = 115, /* Ch 36-48 */ 5858*4882a593Smuzhiyun DOT11_5GHZ_20MHZ_CLASS_2_DFS = 118, /* Ch 52-64 */ 5859*4882a593Smuzhiyun DOT11_5GHZ_20MHZ_CLASS_3 = 124, /* Ch 149-161 */ 5860*4882a593Smuzhiyun DOT11_5GHZ_20MHZ_CLASS_4_DFS = 121, /* Ch 100-140 */ 5861*4882a593Smuzhiyun DOT11_5GHZ_20MHZ_CLASS_5 = 125, /* Ch 149-165 */ 5862*4882a593Smuzhiyun DOT11_5GHZ_40MHZ_CLASS_22 = 116, /* Ch 36-44, lower */ 5863*4882a593Smuzhiyun DOT11_5GHZ_40MHZ_CLASS_23_DFS = 119, /* Ch 52-60, lower */ 5864*4882a593Smuzhiyun DOT11_5GHZ_40MHZ_CLASS_24_DFS = 122, /* Ch 100-132, lower */ 5865*4882a593Smuzhiyun DOT11_5GHZ_40MHZ_CLASS_25 = 126, /* Ch 149-157, lower */ 5866*4882a593Smuzhiyun DOT11_5GHZ_40MHZ_CLASS_27 = 117, /* Ch 40-48, upper */ 5867*4882a593Smuzhiyun DOT11_5GHZ_40MHZ_CLASS_28_DFS = 120, /* Ch 56-64, upper */ 5868*4882a593Smuzhiyun DOT11_5GHZ_40MHZ_CLASS_29_DFS = 123, /* Ch 104-136, upper */ 5869*4882a593Smuzhiyun DOT11_5GHZ_40MHZ_CLASS_30 = 127, /* Ch 153-161, upper */ 5870*4882a593Smuzhiyun DOT11_2GHZ_40MHZ_CLASS_32 = 83, /* Ch 1-7, lower */ 5871*4882a593Smuzhiyun DOT11_2GHZ_40MHZ_CLASS_33 = 84, /* Ch 5-11, upper */ 5872*4882a593Smuzhiyun } dot11_op_class_t; 5873*4882a593Smuzhiyun 5874*4882a593Smuzhiyun /* QoS map */ 5875*4882a593Smuzhiyun #define QOS_MAP_FIXED_LENGTH (8 * 2) /* DSCP ranges fixed with 8 entries */ 5876*4882a593Smuzhiyun 5877*4882a593Smuzhiyun /* BCM proprietary IE type for AIBSS */ 5878*4882a593Smuzhiyun #define BCM_AIBSS_IE_TYPE 56 5879*4882a593Smuzhiyun 5880*4882a593Smuzhiyun /* BCM proprietary flag type for WL_DISCO_VSIE */ 5881*4882a593Smuzhiyun #define SSE_OUI "\x00\x00\xF0" 5882*4882a593Smuzhiyun #define VENDOR_ENTERPRISE_STA_OUI_TYPE 0x22 5883*4882a593Smuzhiyun #define MAX_VSIE_DISASSOC (1) 5884*4882a593Smuzhiyun #define DISCO_VSIE_LEN 0x09u 5885*4882a593Smuzhiyun 5886*4882a593Smuzhiyun /* Single PMK IE */ 5887*4882a593Smuzhiyun #define CCX_SPMK_TYPE 3 /* CCX Extended Cap IE type for SPMK */ 5888*4882a593Smuzhiyun /* CCX Extended Capability IE */ 5889*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct ccx_spmk_cap_ie { 5890*4882a593Smuzhiyun uint8 id; /* 221, DOT11_MNG_PROPR_ID */ 5891*4882a593Smuzhiyun uint8 len; 5892*4882a593Smuzhiyun uint8 oui[DOT11_OUI_LEN]; /* 00:40:96, CISCO_AIRONET_OUI */ 5893*4882a593Smuzhiyun uint8 type; /* 11 */ 5894*4882a593Smuzhiyun uint8 cap; 5895*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5896*4882a593Smuzhiyun typedef struct ccx_spmk_cap_ie ccx_spmk_cap_ie_t; 5897*4882a593Smuzhiyun 5898*4882a593Smuzhiyun /* OWE definitions */ 5899*4882a593Smuzhiyun /* ID + len + OUI + OI type + BSSID + SSID_len */ 5900*4882a593Smuzhiyun #define OWE_TRANS_MODE_IE_FIXED_LEN 13u 5901*4882a593Smuzhiyun 5902*4882a593Smuzhiyun /* Supported Operating Classes element */ 5903*4882a593Smuzhiyun BWL_PRE_PACKED_STRUCT struct supp_op_classes_ie { 5904*4882a593Smuzhiyun uint8 id; 5905*4882a593Smuzhiyun uint8 len; 5906*4882a593Smuzhiyun uint8 cur_op_class; 5907*4882a593Smuzhiyun uint8 op_classes[]; /* Supported Operating Classes */ 5908*4882a593Smuzhiyun } BWL_POST_PACKED_STRUCT; 5909*4882a593Smuzhiyun typedef struct supp_op_classes_ie supp_op_classes_ie_t; 5910*4882a593Smuzhiyun 5911*4882a593Smuzhiyun /* Transition mode (bit number) */ 5912*4882a593Smuzhiyun #define TRANSISION_MODE_WPA3_PSK 0u 5913*4882a593Smuzhiyun #define TRANSITION_MODE_SAE_PK 1u 5914*4882a593Smuzhiyun #define TRANSITION_MODE_WPA3_ENTERPRISE 2u 5915*4882a593Smuzhiyun #define TRANSITION_MODE_ENHANCED_OPEN 3u 5916*4882a593Smuzhiyun 5917*4882a593Smuzhiyun /* This marks the end of a packed structure section. */ 5918*4882a593Smuzhiyun #include <packed_section_end.h> 5919*4882a593Smuzhiyun 5920*4882a593Smuzhiyun #endif /* _802_11_H_ */ 5921