xref: /OK3568_Linux_fs/external/rkwifibt/drivers/bcmdhd/include/802.11.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
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